前端也能获取电池信息,5分钟带你了解奇奇怪怪的知识点

小册

这是我整理的学习资料,非常系统和完善,欢迎一起学习

引言

前端其实也能获取电池信息,以往都是通过客户端提供的JSBridge获取

获取电池信息

通过 Battery Status API,前端可以获取用户设备电池的相关信息,比如电量百分比、充电状态等。

js 复制代码
// 获取 BatteryManager 对象
navigator.getBattery().then(battery => {
  // TODO
});
  • BatteryManager 对象提供了 level、charging、chargingTime 等属性反映电池状态。

  • 监听 chargingchange、levelchange 等事件可以感知状态变化。

不同电量的反馈

获取电池信息后,可以根据电量百分比显示不同的提示:

  • 电量低于 20%时,给出明显的低电量警告,建议立即充电
  • 电量在 20% ~ 40%时,给出友善的充电提醒
  • 电量充足时,不需要特殊反馈

针对充电状态,也可以给出不同的反馈:

  • 当设备处于充电状态,可以显示充电图标、电量数字的充电动画等
  • 不在充电时,显示普通的电量信息
js 复制代码
// 处理不同电量的反馈
function handleBattery(battery) {
  if (battery.level < 0.2) {
    showWarning();
  } else if (battery.level < 0.4) {
    showReminder(); 
  }

  if (battery.charging) {
    showCharging();
  } else {
    showLevel(battery.level);
  }
}

// 监听电池状态变化
navigator.getBattery().then(battery => {
  battery.addEventListener('chargingchange', () => {
    handleBattery(battery);
  });
  
  // ...其他事件监听
})

兼容性

相关推荐
m5655bj4 分钟前
如何通过 C# 实现 PDF 页面裁剪
前端·pdf·c#
这是个栗子5 分钟前
前端开发中的常用工具函数(持续更新中...)
前端·javascript·算法
zhangsansecond6 分钟前
vs创建 基于ASP.NET Framework 的 SOAP 协议 Web 服务,https无法访问
前端·https·asp.net
爱上妖精的尾巴7 分钟前
6-13 WPS JS宏 Map实例2--拆分记录到表格
javascript·restful·wps
Reese_Cool10 分钟前
一篇文章梳理 HTML + CSS 核心知识(含响应式与 Sass)
前端·css·html
幽络源小助理11 分钟前
SpringBoot+Vue多维分类知识管理系统源码 | Java知识库项目免费下载 – 幽络源
java·vue.js·spring boot
雄鸡三声天下白14 分钟前
js复制文本到剪贴板,以及navigator.clipboard 会提示 is undefined
前端·javascript·数据库
OpenTiny社区14 分钟前
博文精读:Chrome CSS 2025年回顾
前端·css·chrome·开源·opentiny
珑墨15 分钟前
【大语言模型】从历史到未来
前端·人工智能·后端·ai·语言模型·自然语言处理·chatgpt
Qin_jiangshan15 分钟前
flutter实现透明导航栏
前端·javascript·flutter