几个有趣的WEB设备API 前端提高B格必备(一)——电池状态&震动api

时间:2023-01-31 23:30:25

受到同事启发,突然发现了几个有趣又实用的web api,没想到前端还有这么多有趣的东西可以玩~~简直过分。

1.电池状态API

navigator.getBattery():这个api返回的是一个promise对象,会给出一个BatteryManager对象,对象中包含了:设备是否在充电,电量,以及还需充电时长和剩余时长等信息。

chrome浏览器、安卓的webview、iphone都可以使用。ie,safari不管是pc还是移动端都不支持。

调用方法如下:

navigator.getBattery().then(function(battery) {
  console.log(battery)
});

console.log打出如下:

几个有趣的WEB设备API    前端提高B格必备(一)——电池状态&震动api

这里我们可以看到返回的对象中有

属性

charging:是否充电;

chargingTime:如果是在充电,还需充电时间;

dischargingTime:电池可用时间

level:剩余电量百分数(是个小数,显示的时候需要处理)

一些可以监听的事件

onchargingchange:监听充电状态的改变

onchargingtimechange:监听充电时间的改变

ondischargingtimechange:监听电池可用时间的改变

onlevelchange:监听剩余电量百分数的改变。  

例子:

if('getBattery' in navigator){
navigator.getBattery().then(function(battery) {
/*
判断是否在充电
*/
if(battery.charging){
$('.isbattery').show();
$('.notbattery').hide(); }else{
$('.isbattery').hide();
$('.notbattery').show();
} /*
判断剩余电量
*/
if(battery.level>=1){
$('.batlevel').html('电池状态:<span class="perbattery_100">电量充沛 ^_^ 还有'+battery.level*100+'%</span>');
}else if(battery.level>=0.5){
$('.batlevel').html('电池状态:<span class="perbattery_50">电量还好 @_@ 还有'+battery.level*100+'%</span>');
}else{
$('.batlevel').html('电池状态:<span class="perbattery_30">啊!快没电了 *_* 还有'+battery.level*100+'%</span>');
} /*
电池事件
*/
battery.addEventListener('chargingchange', function(){
alert("充电状态改变:"+ (battery.charging ? "开始充电" : "不充了"));
}); }else{
$('#batteryarea').text('您的浏览器不支持电池状态接口');
}

上面的代码可以判断出设备是否在充电,以及剩余的电量,移动端和pc端都可以使用。

首先判断了浏览器是否支持这个api;

然后调用navigator.getBattery()接口,由于返回的是promise对象,所以我们使用then()来获取返回的数据。

浏览器返回了BatteryManager对象,然后我们在then的函数内部利用返回的数据写逻辑。

效果如下:

几个有趣的WEB设备API    前端提高B格必备(一)——电池状态&震动api

全部例子:Demo (状态改变时有alert,请不要关闭浏览器的alert功能)

2.震动API

震动在很多游戏及一些h5宣传效果中得到应用,成为一个特色,比如在一些游戏中被地方攻击到的时候让手机产生震动,出现某个效果的时候产生震动,等等。

我们还可以控制它的震动频率。这个api就是:

window.navigator.vibrate(200)

浏览器支持情况:pc端 chrome和火狐支持,ie、opera、Safari不支持

        移动端 Android和火狐是支持的,而苹果手机是不会震动的~~

调用方法:

window.navigator.vibrate([200, 100, 200]);

参数可以使一个数组,其中设定了震动的频率,震动200ms,然后休息100ms,然后再次震动200ms;

取消震动把参数设置为0即可window.navigator.vibrate(0);

这个没有可视化的例子,请在下面的demo中感受~

例子:Demo(会震动,请拿好易碎的安卓机~)

内容原创,转载请注明出处:

作者:Jess_喵

来源:http://www.cnblogs.com/zhangwenjiajessy/p/6240918.html

几个有趣的WEB设备API 前端提高B格必备(一)——电池状态&震动api的更多相关文章

  1. 几个有趣的WEB设备API(二)

    浏览器和设备之间还有很多有趣的接口, 1.屏幕朝向接口 浏览器有两种方法来监听屏幕朝向,看是横屏还是竖屏. (1)使用css媒体查询的方法 /* 竖屏 */ @media screen and (or ...

  2. html5电池状态相关API

    var battery = navigator.battery || navigator.webkitBattery || navigator.mozBattery || navigator.msBa ...

  3. 腾讯Web工程师的前端书单

    2014年一月以来,自己接触web前端开发已经两年多了,记录一下自己前端学习路上看过的,以及道听途说的一些书,基本上按照由浅入深来介绍. JavaScript 入门 <JavaScript权威指 ...

  4. 推荐一份Web 工程师的前端书单

    014年一月以来,自己接触web前端开发已经两年多了,记录一下自己前端学习路上看过的,以及道听途说的一些书,基本上按照由浅入深来介绍. JavaScript 入门 <JavaScript权威指南 ...

  5. Web jquery表格组件 JQGrid 的使用 - 4&period;JQGrid参数、ColModel API、事件及方法

    系列索引 Web jquery表格组件 JQGrid 的使用 - 从入门到精通 开篇及索引 Web jquery表格组件 JQGrid 的使用 - 4.JQGrid参数.ColModel API.事件 ...

  6. web设计师和前端设计师的互动—前端工程师应该具备的三种思维

    如果你是一个天才工程师(马上可以离开),可以独立完成一个很多事情,你可以是一个怪咖,因为我相信没有一个人不会不佩服你.但现实归现实,多数人都不是天才,而我们在职场上也不是单打独斗,我们需要团队合作,需 ...

  7. IOS 特定于设备的开发&colon;检查设备接近度和电池状态

    UIDevice类提供了一些API,使你能够跟踪设备的特征,包括电池的状态和接近度传感器.他们二者都以通知的形式提供更新,可以订阅他们,以便在有重要的更新时通知你的应用程序. 1>启动和禁用接近 ...

  8. 【HTML5】使用 JavaScript 来获取电池状态(Battery Status API)

    HTML5 规范已经越来越成熟,可以让你访问更多来自设备的信息,其中包括最近提交的 "Battery Status API".如其名称所示,该 API 允许你通过 JavaScri ...

  9. python编程之API入门: (二)python3中使用新浪微博API

    回顾API使用的流程 通过百度地图API的使用,我理解API调用的一般流程为:生成API规定格式的url->通过urllib读取url中数据->对json格式的数据进行解析.下一步,开始研 ...

随机推荐

  1. &lbrack;开源&rsqb;基于WPF实现的Gif图片分割器,提取GIf图片中的每一帧

    不知不觉又半个月没有更新博客了,今天终于抽出点时间,来分享一下前段时间的成果. 在网上,我们经常看到各种各样的图片,尤其是GIF图片的动态效果,让整个网站更加富有表现力!有时候,我们看到一些比较好看的 ...

  2. scala中的面向对象定义类,构造函数,继承

    我们知道scala中一切皆为对象,函数也是对象,数字也是对象,它是一个比java还要面向对象的语言. 定义scala的简单类 class Point (val x:Int, val y:Int) 上面 ...

  3. KnockoutJS 3&period;X API 第五章 高级应用&lpar;5&rpar; 使用预处理扩展Knockout绑定语法

    注意:这是一种高级技术,通常仅在创建可重用绑定或扩展语法的库时使用. 这不是你通常需要做的时候使用Knockout构建应用程序. 从Knockout 3.0开始,开发人员可以通过提供在绑定过程中重写D ...

  4. VB中字符串操作函数

    Len Len(string|varname) 返回字符串内字符的数目,或是存储一变量所需的字节数. Trim Trim(string) 将字符串前后的空格去掉 Ltrim Ltrim(string) ...

  5. html表单应用

    <!DOCTYPE html> <html> <head> <meta name="generator" content="HT ...

  6. Activity生命周期与状态保存

    弹出系统对话框,程序仍部分可见 onPause 对话框消失时 onResume   调用一个新的Activity,老的Activity不可见时 onPause->onStop 从新的Activi ...

  7. scala-spark练手--dataframe数据可视化初稿

    成品:http://www.cnblogs.com/drawwindows/p/5640606.html 初稿: import org.apache.spark.sql.hive.HiveContex ...

  8. A Tour of Go Slicing slices

    ---恢复内容开始--- Slices can be re-sliced, creating a new slice value that points to the same array. The ...

  9. android开发的学习路线

    参考资料:千锋3G学院--课程大纲    http://www.mobiletrain.org 看了专业的培训机构的课程大纲,才知道,自己学习android的路途才刚刚开始!特此整理分享一下,希望能帮 ...

  10. dojo&period;create&bsol;dojo&period;place&bsol;dojo&period;empty&bsol;dojo&period;destroy&bsol;dojo&period;body

    1.dojo.create 1.create a node; 2.set attributes on it;  3.place it in the DOM. dojo.create(/*String| ...