Is there a way to retrieve the present time in Shanghai using JavaScript?

I'm working on a small project and need to obtain the current time in JavaScript specifically for Shanghai. Does anyone have any tips or recommendations on how I can achieve this efficiently?

Answer №1

Being the lazy person that I am, I decided to utilize moment.js:

let current = moment();
let timeInTokyo = current.tz('Asia/Tokyo').format('h:mma');

Answer №2

In China, the entire country observes a single timezone known as UCT+08:00. If you need to determine the current time in Shanghai based on the system settings of the host, you can calculate it by obtaining the local time, factoring in the timezone offset (ECMAScript measures timezone offset in minutes to adjust to UTC, so for instance, UTC+10:00 would be -600), and then additionally incorporating the offset specific to Shanghai:

function timeInShanghai() {
  function z(n){return (n<10?'0':'') + n}
  var d = new Date();
  d.setMinutes(d.getMinutes() + d.getTimezoneOffset() + 480);
  return z(d.getHours()) + ':' + z(d.getMinutes()) + ':' + z(d.getSeconds());
}

This method may not be entirely reliable if there are changes in the timezone rules or the implementation of daylight saving time.

Answer №3

Shanghai operates on a timezone offset of +8 hours. In order to obtain the current date and time:

let currentTime = new Date().getTime();

To break down the time into hours, minutes, and seconds:

seconds = parseInt((currentTime / 1000) % 60);

hours = parseInt((currentTime / (1000 * 60 * 60)) % 24) + 8; \\adjusting for the offset

minutes = parseInt((currentTime / (1000 * 60)) % 60);

To display the time in string format:

console.log(hours + ":" + minutes + ":" + seconds);

Similar questions

If you have not found the answer to your question or you are interested in this topic, then look at other similar questions below or use the search

Running a Neo4j Cypher query with the help of jQuery

I've been attempting to create an Ajax call using jQuery to a Neo4j Server, both residing on the same machine. However, I keep encountering errors in the response. This is how my ajax call is written: var request = $.ajax({ type: "POST", url ...

Bootstrap tab content getting shifted downwards

Having an issue with the Tab plugin in Bootstrap on a particular page. The tab body is being pushed down 400px below the actual tabs. This behavior is only occurring on this specific page, while most other pages using the same plugin are functioning fine. ...

Iterate through elements within an HTML table by utilizing jQuery

I have a table. My goal is to loop through all the items in the table and extract their quality and price data. However, I'm struggling to access these values efficiently. Here is the structure of the table: <div class="table-items__container"&g ...

Activate video playback when scrolling, but ensure it only occurs one time

I've encountered an issue with my script that is meant to play a video when it reaches a certain position on scroll. The problem is, if the video is paused and scrolling continues, it starts playing again. I attempted to use just one scroll function b ...

Playing audio induces slight delay

Issue: I created a game similar to Flappy Bird using Three.js. Every time I tap the screen, a flapping sound is triggered. However, playing this audio causes a slight lag in the game, making it less smooth. The lag only occurs when the audio is played and ...

Error thrown: Uncaught TypeError - Attempted to access 'params' property of undefined object in the context of StudentDetails

I've encountered an issue where I need to transfer student application data from my server-side to my client-side. Whenever a new student application is created, I want to display their information on my StudentDetails.jsx file. Here is my Server.js c ...

Transitioning from an asp.mvc application to a node.js application, with a strong emphasis on enhancing the design aspects

I am currently exploring different platforms to transition an existing application. The initial version was built using asp.mvc, but the majority of the code is in javascript with a simple asp mvc web service. As we plan to move forward, it seems logical t ...

apostrophe cutting off a portion of the input field's value

I am facing an issue with a reloaded input box on a web page that is updated through an ajax call. Whenever the input contains a single quote, the rest of the value gets cut off. How can I resolve this problem? The value assigned to myVal dynamically from ...

javascript - The Key Pair of a Jquery Object is Not Defined

I'm currently going through an HTML element, which is an input field using jQuery, but I keep encountering an error. Here's the code snippet: $(".submit_button").on("click touch", function(e){ e.preventDefault(); var formdat ...

Node.js is throwing an error "Unexpected token v in JSON at position 0" which

I'm currently working on developing PHP code within the Google App Engine flexible environment. Specifically, I am facing some challenges in setting up the Firebase SDK Admin for the web version. My main struggle lies with the following block of code ...

Components in array not displaying in React

I've been struggling to generate a table from an array in React. Typically, I retrieve data from a database, but for testing purposes, I manually created the array to ensure the data is correct. Despite following examples by enclosing my map code with ...

Adjust the sequence of the series in dimple's multi-series chart using interactive features

My latest project involves a unique dimple interactive chart featuring two series: a pie series and a line series based on the same dataset. You can view the chart at dimplejs.org/advanced_examples_viewer.html?id=advanced_interactive_legends Check out the ...

Error occurs in Javascript when attempting to execute javascript code using PHP's echo and an unexpected identifier token is encountered

Currently, I am trying to insert a div into the page when a specific condition is met in PHP: if ($var == 0) { echo '<script>console.log("Test."); var res = document.getElementById("response"); res.innerHTML = "<div class='h ...

Encountering Issue: Trying to modify the getter of an immutable property in React Native

I encountered an error while working on my react-native project The error message reads: Attempting to change the getter of an unconfigurable property import * as React from 'react'; import { Text, View, StyleSheet } from 'react-native&ap ...

Unable to display PHP response in a div using AJAX - issue persisting

Hey there! I'm currently working on a project where I want the form submission to load a response into a div without refreshing the page. I've looked at various examples of ajax forms with PHP online, but haven't been able to solve my issue ...

What is the best way to test an external Data Transfer Object (DTO

I am looking to test an external Data Transfer Object (DTO) that undergoes frequent changes. For example: Here is a sample JavaScript (JSON) file below: // JavaScript const type User = { id: Number, name: String } // JSON user: { id: Number, ...

Using Jquery's append() method to dynamically alter the HTML content

I am attempting to create a table with rows that are added dynamically. The challenge I am encountering is that each row consists of form elements, including multiple inputs. I have a PHP function that generates the correct row, and I have been able to sen ...

When attempting to modify an element in an array within a state-managed object, the input field loses focus

In attempting to address my issue, I have crafted what I believe to be the most concise code example. The main goal is to display a table on the page populated with exercise data retrieved from a database. This data is then assigned to an array of objects ...

Importing multiple exports dynamically in Next.js

My current setup involves using a third-party package that I load dynamically in Next.js: const am5 = dynamic(() => import("@amcharts/amcharts5"), {ssr: false}) The imported amcharts5 consists of various exports and imports, such as: export { ...

Error encountered in Jest (a testing tool for React) - Parse Error: Line 1 contains an invalid import declaration

Currently, I am utilizing node.js version 0.10.x and jest version 0.4.x to conduct tests on react.js. Prior to testing my react components, I was utilizing node.js version 0.12.x. I switched to version 0.10.x using nvm. I proceeded to rebuild all modules ...