JavaScript手機(jī)振動(dòng)API
很明顯,這個(gè)API就是允許mobile程序員使用JavaScript調(diào)用手機(jī)的振動(dòng)功能,并且能設(shè)定振動(dòng)的方式和時(shí)長(zhǎng)。
判斷瀏覽器對(duì)振動(dòng)API的支持情況
一個(gè)好的習(xí)慣就是在使用之前要檢查一下當(dāng)前你的應(yīng)用環(huán)境、瀏覽器是否支持振動(dòng)API。下面就是檢測(cè)的方法:
// Standards ftw! var supportsVibrate = "vibrate" in navigator;
在window.navigator對(duì)象里就只有一個(gè)關(guān)于振動(dòng)的API:vibrate。
振動(dòng)API基礎(chǔ)應(yīng)用
這個(gè)navigator.vibrate函數(shù)可以接受一個(gè)數(shù)字參數(shù),也可以接受一個(gè)數(shù)字?jǐn)?shù)組,當(dāng)使用數(shù)組參數(shù)時(shí),奇數(shù)位的數(shù)值是震動(dòng)秒數(shù),偶數(shù)位為等待秒數(shù)。
// 振動(dòng)1秒 navigator.vibrate(1000); // 振動(dòng)多次 // 參數(shù)分別是震動(dòng)3秒,等待2秒,然后振動(dòng)1秒 navigator.vibrate([3000, 2000, 1000]);
如果想停止震動(dòng),你只需要向navigator.vibrate方法里傳入0,或一個(gè)空數(shù)組:
// 停止振動(dòng) navigator.vibrate(0); navigator.vibrate([]);
需要提醒的是,對(duì)navigator.vibrate方法的調(diào)用并不會(huì)引起手機(jī)循環(huán)振動(dòng);當(dāng)參數(shù)是一個(gè)數(shù)字時(shí),振動(dòng)之后發(fā)生一次,然后就停止下來(lái)。當(dāng)參數(shù)是數(shù)組時(shí),震動(dòng)會(huì)按數(shù)組里的值震動(dòng),然后就停止振動(dòng)。
持續(xù)震動(dòng)
我們可以簡(jiǎn)單的使用setInterval 和 clearInterval 方法產(chǎn)生讓手機(jī)持續(xù)震動(dòng)的效果:
var vibrateInterval; // Starts vibration at passed in level function startVibrate(duration) { navigator.vibrate(duration); } // Stops vibration function stopVibrate() { // Clear interval and stop persistent vibrating if(vibrateInterval) clearInterval(vibrateInterval); navigator.vibrate(0); } // Start persistent vibration at given duration and interval // Assumes a number value is given function startPeristentVibrate(duration, interval) { vibrateInterval = setInterval(function() { startVibrate(duration); }, interval); }
上面的這段代碼只是針對(duì)振動(dòng)參數(shù)是一個(gè)數(shù)字的情況,如果參數(shù)是數(shù)組,你還需要計(jì)算一下它的總共持續(xù)時(shí)間,然后根據(jù)它的特征來(lái)進(jìn)行循環(huán)。
使用振動(dòng)(Vibration) API的場(chǎng)景
這個(gè)API顯然是針對(duì)移動(dòng)手機(jī)設(shè)備的。當(dāng)開發(fā)手機(jī)WEB移動(dòng)應(yīng)用時(shí),它是一個(gè)很好的警示工具,當(dāng)在開發(fā)Web游戲或多媒體應(yīng)用時(shí),這個(gè)振動(dòng)功能更是不可或缺的好技術(shù)。比如說(shuō),當(dāng)用戶在用一個(gè)手機(jī)玩你的WEB游戲時(shí),當(dāng)游戲中發(fā)生爆炸,而你讓手機(jī)也跟隨著振動(dòng),是不是一種很出色的用戶體驗(yàn)?
你對(duì)這個(gè)JavaScript振動(dòng)API的感覺(jué)如何?是認(rèn)為它會(huì)很快流行起來(lái)?還是沒(méi)有多大用處?
相關(guān)文章
js+canvas實(shí)現(xiàn)滑動(dòng)拼圖驗(yàn)證碼功能
這篇文章主要介紹了js+canvas實(shí)現(xiàn)滑動(dòng)拼圖驗(yàn)證碼功能,本文結(jié)合實(shí)例代碼分步驟給大家介紹的非常詳細(xì),需要的朋友可以參考下2018-03-03JavaScript如何借用構(gòu)造函數(shù)繼承
這篇文章主要介紹了JavaScript如何借用構(gòu)造函數(shù)繼承,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-11-11JavaScript實(shí)現(xiàn)彈出DIV層同時(shí)頁(yè)面背景漸變成半透明效果
這篇文章主要介紹了JavaScript實(shí)現(xiàn)彈出DIV層同時(shí)頁(yè)面背景漸變成半透明效果,涉及JavaScript彈出窗口的實(shí)現(xiàn)及頁(yè)面元素屬性動(dòng)態(tài)變換的相關(guān)技巧,需要的朋友可以參考下2016-03-03用js實(shí)現(xiàn)終止瀏覽器對(duì)頁(yè)面HTML的繼續(xù)解析即停止解析 兼容firefox
用js實(shí)現(xiàn)終止瀏覽器對(duì)頁(yè)面HTML的繼續(xù)解析即停止解析 兼容firefox...2007-11-11JS實(shí)現(xiàn)百度搜索框關(guān)鍵字推薦
這篇文章主要為大家詳細(xì)介紹了JS實(shí)現(xiàn)百度搜索框關(guān)鍵字推薦,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-02-02JavaScript異步編程操作實(shí)現(xiàn)介紹
異步(Asynchronous, async)是與同步(Synchronous, sync)相對(duì)的概念。在我們學(xué)習(xí)的傳統(tǒng)單線程編程中,程序的運(yùn)行是同步的,同步不意味著所有步驟同時(shí)運(yùn)行,而是指步驟在一個(gè)控制流序列中按順序執(zhí)行,而異步的概念則是不保證同步的概念2022-09-09一文讓你徹底弄懂js中undefined和null的區(qū)別
JavaScript是一門動(dòng)態(tài)類型語(yǔ)言,元素除了表示存在的空值外,還有可能根本就不存在,這就是undefined存在的原因,這篇文章主要給大家介紹了關(guān)于undefined和null區(qū)別的相關(guān)資料,需要的朋友可以參考下2022-03-03