使用 JavaScript 获取电池状态

在现代的移动设备和笔记本电脑上,了解电池状态是一项非常有用的功能。使用 JavaScript 可以轻松地获取电池的充电状态、电量百分比等信息。本文将介绍如何使用 JavaScript 访问这些信息,并将其显示在网页上。

1. HTML 结构

首先,我们需要一个简单的 HTML 结构来显示电池状态信息:

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Battery Status</title>
</head>
<body>
  <div>
    <h1>Battery Status</h1>
    <p><strong>Charge Level:</strong> <span id="charge-level">--</span>%</p>
    <p><strong>Charging:</strong> <span id="charging-status">--</span></p>
  </div>

  <script src="battery.js"></script>
</body>
</html>

2. JavaScript 代码

接下来,我们创建 battery.js 文件,并在其中编写 JavaScript 代码来获取和更新电池状态信息:

javascript 复制代码
document.addEventListener("DOMContentLoaded", function() {
  navigator.getBattery().then(function(battery) {

    function updateBatteryInfo() {
      document.getElementById('charge-level').textContent = battery.level * 100 + '%';
      document.getElementById('charging-status').textContent = battery.charging ? 'Charging' : 'Not Charging';
    }

    // 初始化电池信息
    updateBatteryInfo();

    // 当电池状态发生变化时更新信息
    battery.addEventListener('levelchange', updateBatteryInfo);
    battery.addEventListener('chargingchange', updateBatteryInfo);
  });
});

在这段代码中,我们首先通过 navigator.getBattery() 方法获取电池对象,然后注册了两个事件监听器,分别是 levelchangechargingchange,用于在电池状态发生变化时更新网页上的信息。

相关推荐
微风中的麦穗2 小时前
【MATLAB】MATLAB R2025a 详细下载安装图文指南:下一代科学计算与工程仿真平台
开发语言·matlab·开发工具·工程仿真·matlab r2025a·matlab r2025·科学计算与工程仿真
2601_949146532 小时前
C语言语音通知API示例代码:基于标准C的语音接口开发与底层调用实践
c语言·开发语言
开源技术2 小时前
Python Pillow 优化,打开和保存速度最快提高14倍
开发语言·python·pillow
学嵌入式的小杨同学2 小时前
从零打造 Linux 终端 MP3 播放器!用 C 语言实现音乐自由
linux·c语言·开发语言·前端·vscode·ci/cd·vim
mftang4 小时前
Python 字符串拼接成字节详解
开发语言·python
jasligea4 小时前
构建个人智能助手
开发语言·python·自然语言处理
yuezhilangniao4 小时前
AI智能体全栈开发工程化规范 备忘 ~ fastAPI+Next.js
javascript·人工智能·fastapi
kokunka4 小时前
【源码+注释】纯C++小游戏开发之射击小球游戏
开发语言·c++·游戏
云栖梦泽5 小时前
易语言开发从入门到精通:补充篇·网络编程进阶+实用爬虫开发·API集成·代理IP配置·异步请求·防封禁优化
开发语言
java1234_小锋5 小时前
Java高频面试题:SpringBoot为什么要禁止循环依赖?
java·开发语言·面试