Maison >interface Web >js tutoriel >Comment puis-je obtenir de manière fiable le fuseau horaire et le décalage horaire d'un client à l'aide de JavaScript ?

Comment puis-je obtenir de manière fiable le fuseau horaire et le décalage horaire d'un client à l'aide de JavaScript ?

Mary-Kate Olsen
Mary-Kate Olsenoriginal
2024-12-31 17:19:11571parcourir

How Can I Reliably Get a Client's Time Zone and Offset Using JavaScript?

Récupération du fuseau horaire et du décalage horaire du client en JavaScript

La détermination du fuseau horaire du visiteur est cruciale pour diverses applications, telles que l'affichage de la date et de l'heure localisées information. Cet article explique comment obtenir à la fois le fuseau horaire et son décalage par rapport à UTC ou GMT à l'aide de JavaScript.

Comprendre le fuseau horaire et le décalage

Un fuseau horaire définit une région qui observe une heure spécifique par rapport au temps universel coordonné (UTC) ou au temps moyen de Greenwich (GMT). Un décalage est la différence en heures entre un fuseau horaire particulier et UTC. Par exemple, l'heure d'Europe centrale (CET) est dans le décalage UTC 01, ce qui indique qu'elle est en avance d'une heure sur UTC.

Collecte d'informations sur le fuseau horaire

Traditionnellement, les navigateurs fournissaient des API JavaScript pour récupérer le fuseau horaire du client. Cependant, ces API ne sont pas fiables en raison d'inexactitudes potentielles et de problèmes de sécurité.

Approche moderne : utilisation de l'API Intl

La méthode recommandée pour obtenir le fuseau horaire IANA du système en JavaScript consiste à utiliser l'API Intl.DateTimeFormat(). Cette API renvoie un objet contenant des informations sur les paramètres régionaux du client, y compris le fuseau horaire.

Exemple de code

Le code suivant montre comment récupérer le fuseau horaire à l'aide de l'outil API Intl.DateTimeFormat() :

const options = { timeZone: 'UTC' };
const dateFormatter = new Intl.DateTimeFormat([], options);
console.log(dateFormatter.resolvedOptions().timeZone);

Ce code enregistre le fuseau horaire IANA, qui reflète avec précision l'heure système du client zone.

Attention : Calcul du décalage

Il est important de noter que le calcul du décalage par rapport à UTC en fonction de l'heure actuelle n'est pas recommandé. Les fuseaux horaires et les règles d’heure d’été peuvent subir des changements tout au long de l’année. S'appuyer sur des calculs de décalage peut entraîner des écarts. Au lieu de cela, utilisez toujours le fuseau horaire IANA du système pour obtenir des informations précises sur le fuseau horaire.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn