Table des matières
Quelles informations ont-t-elle fourni?
Pourquoi a-t-il été obsolète?
Alternatives et meilleures pratiques
Fin de compte
Maison interface Web Tutoriel H5 Quelle est l'API d'état de la batterie dans HTML5?

Quelle est l'API d'état de la batterie dans HTML5?

Aug 01, 2025 am 07:16 AM

L'API d'état de la batterie a fourni le niveau de la batterie, l'état de charge, le temps de charge et le temps de décharge via l'objet BatteryManager. 2. Il a été obsolète en raison des risques de confidentialité, de la faible nécessité et du support de navigateur incohérent. 3. Les principaux navigateurs comme Chrome et Firefox l'ont supprimé ou désactivé à partir de 2022. 4. Les alternatives incluent l'API d'information réseau, Navigator.online, CSS / JavaScript Performance Heuristics et le respect des préférences des utilisateurs comme les données pré-réduites ou les préfères réduites en réduction. 5. L'API est désormais obsolète et les développeurs ne devraient pas l'utiliser dans de nouveaux projets en raison de problèmes de confidentialité et de manque de soutien.

Quelle est l'API d'état de la batterie dans HTML5?

L' API d'état de la batterie dans HTML5 est une API Web qui permet aux sites Web d'accéder aux informations sur le niveau de batterie et l'état de charge de l'appareil. Bien qu'il ne fasse jamais officiellement partie de la spécification HTML5 finale et a depuis été obsolète ou supprimé dans la plupart des navigateurs modernes en raison de problèmes de confidentialité et de sécurité, il a été utilisé autrefois pour améliorer l'expérience utilisateur en fonction des conditions de la batterie.

Quelle est l'API d'état de la batterie dans HTML5?

Voici comment cela a fonctionné et pourquoi cela comptait:

Quelles informations ont-t-elle fourni?

L'API a exposé un objet BatteryManager via navigator.getBattery() , qui a renvoyé une promesse qui a résolu un objet contenant des propriétés liées à la batterie:

Quelle est l'API d'état de la batterie dans HTML5?
  • charging - un booléen indiquant si l'appareil charge.
  • chargingTime - Le nombre de secondes restant jusqu'à ce que la batterie soit complètement chargée (renvoie 0 si elle est déjà facturée ou non).
  • dischargingTime - le nombre estimé de secondes avant la batterie de la batterie.
  • level - Une valeur comprise entre 0 et 1 représentant le niveau de charge de la batterie (par exemple, 0,55 signifie 55%).

Exemple d'utilisation:

 Navigator.getBattery (). puis (fonction (batterie) {
  Console.log ("Niveau de la batterie:", Battery.level * 100 "%");
  console.log ("Charge:", batterie.Charging);
  Console.log ("Time to Charge:", batterie.Chargingtime, "secondes");
  Console.log ("Temps de décharge:", batterie.Dischargingtime, "secondes");
});

Pourquoi a-t-il été obsolète?

Malgré son utilité, l'API d'état de la batterie a soulevé plusieurs préoccupations:

Quelle est l'API d'état de la batterie dans HTML5?
  • Risques de confidentialité : le niveau de batterie et le comportement de charge peuvent être utilisés dans le cadre d'une technique d'empreintes digitales pour suivre les utilisateurs sur les sites sans leur consentement.
  • Faible nécessité : la plupart des sites Web n'ont pas besoin d'informations sur la batterie et les alternatives (comme l'ajustement de l'interface utilisateur en fonction des performances de l'appareil ou des conditions de réseau) peuvent souvent atteindre des objectifs similaires.
  • Implémentation incohérente : le support a varié selon les navigateurs, et certains ne l'ont jamais implémenté.

Par conséquent:

  • Chrome a supprimé le support à partir de la version 105 (2022).
  • Firefox l'a désactivé par défaut et l'a ensuite supprimé.
  • D'autres navigateurs majeurs ont emboîté le pas ou ne l'ont jamais soutenu.

Alternatives et meilleures pratiques

Au lieu de s'appuyer sur l'état de la batterie, les développeurs sont encouragés à utiliser d'autres API et stratégies:

  • API d'information réseau - Ajustez le contenu en fonction de la vitesse de connexion (par exemple, desservez des supports de qualité inférieure sur des réseaux lents).
  • navigator.onLine - détecter si l'utilisateur est hors ligne.
  • CSS et heuristique JavaScript - Réduisez les animations ou les tâches d'arrière-plan sur les dispositifs à basse performance.
  • Préférences de l'utilisateur - Respectez les astuces prefers-reduced-data ou prefers-reduced-motion .

Fin de compte

L'API d'état de la batterie était une fonctionnalité qui permettait aux sites Web de vérifier l'état de la batterie d'un appareil, mais il est désormais largement obsolète en raison de problèmes de confidentialité. Bien qu'il offre des possibilités intéressantes pour optimiser les performances ou l'expérience utilisateur, le développement Web moderne se concentre sur des alternatives préservant la confidentialité. Donc, vous ne devriez pas en compter dans de nouveaux projets .

Fondamentalement, c'est un bon exemple d'une fonctionnalité qui semblait utile mais qui n'a pas survécu à l'équilibre entre l'utilité et la confidentialité des utilisateurs.

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 de ce site Web
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

Outils d'IA chauds

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

Video Face Swap

Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Article chaud

Porce de variable PHP expliquée
1 Il y a quelques mois By 百草
Commentant le code en php
1 Il y a quelques mois By 百草
<🎜>: Grow A Garden - Guide complet des marchands itinérants
4 Il y a quelques semaines By Jack chen
Conseils pour écrire des commentaires PHP
1 Il y a quelques mois By 百草

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds

Tutoriel PHP
1511
276
Pourquoi mon image n'apparaît-elle pas dans HTML? Pourquoi mon image n'apparaît-elle pas dans HTML? Jul 28, 2025 am 02:08 AM

L'image non affichée est généralement causée par un mauvais chemin de fichier, un nom ou une extension de fichier incorrect, des problèmes de syntaxe HTML ou un cache de navigateur. 1. Assurez-vous que le chemin SRC est cohérent avec l'emplacement réel du fichier et utilisez le chemin relatif correct; 2. Vérifiez si le cas de fichier et l'extension correspondent exactement et vérifiez si l'image peut être chargée en entrant directement l'URL; 3. Vérifiez si la syntaxe TAG IMG est correcte, assurez-vous qu'il n'y a pas de caractères redondants et que la valeur d'attribut ALT est appropriée; 4. Essayez de forcer l'actualisation de la page, de nettoyer le cache ou d'utiliser le mode incognito pour éliminer les interférences du cache. Le dépannage dans cet ordre peut résoudre la plupart des problèmes d'affichage d'image HTML.

Comment utiliser les boutons radio dans HTML5? Comment utiliser les boutons radio dans HTML5? Jul 21, 2025 am 01:08 AM

La clé de l'utilisation de boutons radio dans HTML5 est de comprendre comment ils fonctionnent et d'organiser correctement la structure du code. 1. L'attribut de nom de chaque bouton radio doit être le même pour obtenir une sélection mutuellement exclusive; 2. Utilisez des balises d'étiquette pour améliorer l'accessibilité et cliquer sur l'expérience; 3. Il est recommandé d'envelopper chaque option dans une div ou un étiquette pour améliorer la clarté structurelle et le contrôle du style; 4. Définissez les sélections par défaut via l'attribut vérifié; 5. La valeur de la valeur doit être concise et significative, ce qui est pratique pour le traitement de soumission de formulaire; 6. Le style peut être personnalisé via CSS, mais la fonction doit être assurée d'être normale. La maîtrise de ces points clés peut éviter efficacement des problèmes courants et améliorer l'efficacité de l'utilisation.

CMS sans tête et génération de sites statiques (SSG) avec Astro CMS sans tête et génération de sites statiques (SSG) avec Astro Jul 26, 2025 am 07:31 AM

Utilisez des CM sans tête en conjonction avec la génération de sites statiques d'Astro (SSG) pour créer des sites Web hautes performances et axés sur le contenu. 2.Astro obtient du contenu de la CMS sans tête (comme la santé mentale, le contenu, la strapi, le wordpress ou les datocms) via des API et des pré-rendements en tant que pages statiques. 3. Utilisez getStaticPaths () pour générer le chemin de la page, obtenir des données via les appels CMSAPI et séparer le contenu de la frontale. 4. Les avantages comprennent d'excellentes performances (chargement rapide, SEO-friendly), une expérience d'édition amicale, une flexibilité architecturale, une haute sécurité et une évolutivité. 5. Les mises à jour du contenu nécessitent une reconstruction du site, et vous pouvez utiliser CMSWebHook pour toucher

La balise  est-elle toujours utilisée dans HTML5? La balise est-elle toujours utilisée dans HTML5? Jul 21, 2025 am 02:47 AM

Oui, il fait partie de HTML5, mais son utilisation a progressivement diminué et est controversée. Utilisé pour combiner le titre principal avec le sous-titre afin que seul le plus haut niveau de titres soit identifié dans le plan du document; Par exemple, le titre principal et le sous-titre peuvent être enveloppés pour indiquer qu'ils ne sont que des titres auxiliaires plutôt que des titres de chapitre indépendants; Cependant, les raisons pour lesquelles ils ne sont plus largement utilisées incluent: 1. Les lecteurs du navigateur et de l'écran leur sont un support incohérent, 2. Il existe des alternatives plus simples telles que l'utilisation de CSS pour contrôler les styles, 3. L'algorithme de contour du document HTML n'est pas largement pris en charge; Malgré cela, il peut toujours être pris en compte dans des sites Web ou des documents avec des exigences sémantiques élevées; Alors que dans la plupart des cas, les développeurs ont tendance à utiliser un seul, à gérer les styles via CSS et à maintenir des niveaux de titre clairs.

API H5 Web MIDI pour les surfaces de contrôle avancées API H5 Web MIDI pour les surfaces de contrôle avancées Jul 19, 2025 am 03:04 AM

Pour utiliser WebMidiapi pour créer une interface de contrôle avancée, vous devez d'abord obtenir des autorisations de périphérique, demander l'autorisation via Navigator.RequestMidiaCcess () et les périphériques d'entrée et de sortie de processus; Deuxièmement, écoutez ou envoyez des messages MIDI, tels que l'écoute des opérations de bouton via l'entrée.addeventListener, et envoyez des instructions de contrôle LED via la sortie.Send; Vous devez également vous adapter à différents contrôleurs, établir des fichiers de configuration ou fournir des fonctions de mappage définies par l'utilisateur; Enfin, faites attention aux compétences en développement telles que la réponse en temps réel, la gestion des erreurs, les outils de débogage et la correspondance des numéros de canal.

L'importance du HTML sémantique pour le référencement et l'accessibilité L'importance du HTML sémantique pour le référencement et l'accessibilité Jul 30, 2025 am 05:05 AM

SémantichtmlimprovesbothseoandaccessibilityByusing a été ultime

API d'informations réseau H5 pour le chargement adaptatif API d'informations réseau H5 pour le chargement adaptatif Jul 23, 2025 am 04:15 AM

L'API NetworkInformation de H5 peut optimiser les stratégies de chargement en jugeant le type de réseau. ① Utilisez Navigator.Connection pour obtenir le type de réseau et l'état en ligne; ② décider de charger des ressources à haute définition ou un contenu léger en fonction des valeurs efficaces (telles que lent-2g, 4g, 5g); ③ Ajustez dynamiquement la stratégie de chargement en écoutant des événements de changement; ④ Faites attention à des problèmes tels que la compatibilité, les restrictions limitées de support iOS et de mode de confidentialité.

H5 Barcode et QR Code Scanning avec GetUserMedia H5 Barcode et QR Code Scanning avec GetUserMedia Jul 20, 2025 am 02:03 AM

La page H5 réalise les fonctions de numérisation de code-bar et de code QR, principalement en appelant GetUserMedia pour obtenir des autorisations de caméra et la combiner avec la bibliothèque de décodage pour une identification en temps réel. 1. Utilisez d'abord GetUserMedia pour obtenir des autorisations de caméra et lier le flux vidéo à la balise. Faites attention aux différences dans l'environnement HTTPS et la prise en charge des appareils; 2. En interceptant les trames vidéo et en extraction des données d'image, contrôlez la fréquence de reconnaissance pour optimiser les performances; 3. Utilisez des bibliothèques de décodage telles que le zxing ou les quaggajs pour la reconnaissance d'image, il est recommandé d'empêcher les résultats de reconnaissance; 4. En termes de compatibilité, les contraintes vidéo peuvent être définies pour optimiser l'adaptation des périphériques et améliorer l'expérience utilisateur via des invites d'interface utilisateur; 5. En termes d'optimisation des performances, il est recommandé d'utiliser un travailleur Web pour effectuer des tâches de décodage pour éviter de bloquer le principal

See all articles