使用html5新特性輕松監(jiān)聽(tīng)任何App自帶返回鍵的示例

1、前言
如今h5新特性、新標(biāo)簽、新規(guī)范等有很多,而且正在不斷完善中,各大瀏覽器商對(duì)它們的支持,也是相當(dāng)給力。作為前端程序員,我覺(jué)得我們還是有必要積極關(guān)注并勇敢地加以實(shí)踐。接下來(lái)我將和各位分享一個(gè)特別好用的h5新特性(目前也不是特別新),輕松監(jiān)聽(tīng)任何App自帶的返回鍵,包括安卓機(jī)里的物理返回鍵,從而實(shí)現(xiàn)項(xiàng)目開(kāi)發(fā)中進(jìn)一步的需求。
2、起因
大概半年前接到pm一需求,用純h5實(shí)現(xiàn)多audio的播放、暫停、續(xù)播,頁(yè)面放至駕考寶典App中,與客戶端沒(méi)有任何的交互,所以與客戶端相關(guān)的js不需要引用??瓷先ミ@需求挺簡(jiǎn)單的嘛,雖然之前也沒(méi)做過(guò)類似的需求。不管三七二十一,擼起袖子就是干。開(kāi)始了學(xué)習(xí)之旅。
3、我這里著重介紹下我具體是怎么監(jiān)聽(tīng)任何App自帶的返回鍵,以及安卓機(jī)里的物理返回鍵。
那為什么我要去監(jiān)聽(tīng)呢,這里我有必要強(qiáng)調(diào)強(qiáng)調(diào)再?gòu)?qiáng)調(diào)。蘋果手機(jī)不管是微信、QQ、App,還是瀏覽器里,涉及到audio、video,返回上一頁(yè)系統(tǒng)會(huì)自動(dòng)暫停當(dāng)前的播放的,但不是所有安卓機(jī)都可以。所以我們自己必須自定義監(jiān)聽(tīng)。很多朋友可能第一想法就是百度,然后出來(lái)的答案無(wú)非是這樣
pushHistory(); window.addEventListener("popstate", function(e) { alert("我監(jiān)聽(tīng)到了瀏覽器的返回按鈕事件啦");//根據(jù)自己的需求實(shí)現(xiàn)自己的功能 }, false); function pushHistory() { var state = { title: "title", url: "#" }; window.history.pushState(state, "title", "#"); }
是不是很眼熟?然而關(guān)鍵需求不能完美實(shí)現(xiàn),要這段代碼有何用,當(dāng)時(shí)我也是絞盡腦汁。直到經(jīng)過(guò)大神好友指導(dǎo),復(fù)制了這段代碼
var hiddenProperty = 'hidden' in document ? 'hidden' : 'webkitHidden' in document ? 'webkitHidden' : 'mozHidden' in document ? 'mozHidden' : null; var visibilityChangeEvent = hiddenProperty.replace(/hidden/i, 'visibilitychange'); var onVisibilityChange = function(){ if (!document[hiddenProperty]) { console.log('頁(yè)面非激活'); }else{ console.log('頁(yè)面激活') } } document.addEventListener(visibilityChangeEvent, onVisibilityChange);
所有問(wèn)題迎刃而解。
這段代碼的原理我個(gè)人理解就是通過(guò)判斷用戶瀏覽的是否為當(dāng)前頁(yè),從而進(jìn)行相關(guān)操作。
這是 MDN相關(guān)鏈接:https://developer.mozilla.org/zh-CN/docs/Web/API/Document/hidden
并不是說(shuō)真的可以通過(guò)JS監(jiān)聽(tīng)到App里的自帶返回鍵,甚至安卓的物理返回鍵,而是通過(guò)轉(zhuǎn)變思路,快速實(shí)現(xiàn)需求。希望這個(gè)特性能幫到各位。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
css3實(shí)現(xiàn)動(dòng)畫(huà)的三種方式
這篇文章主要介紹了css3實(shí)現(xiàn)動(dòng)畫(huà)的三種方式,幫助大家更好的理解和學(xué)習(xí)css3,感興趣的朋友可以了解下2020-08-24如何使用css3實(shí)現(xiàn)一個(gè)類在線直播的隊(duì)列動(dòng)畫(huà)的示例代碼
這篇文章主要介紹了如何使用css3實(shí)現(xiàn)一個(gè)類在線直播的隊(duì)列動(dòng)畫(huà)的示例代碼,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下2020-06-17- 有好多小伙伴私聊我問(wèn)我html5新特性 和用法,下面我給大家具體介紹一下html5都新加了哪些新特性,感興趣的朋友跟隨腳本之家小編一起看看吧2018-09-13
- 這篇文章主要介紹了HTML5新特性之type=file文件上傳功能,需要的朋友可以參考下2018-02-02
- HTML5 只有一個(gè)簡(jiǎn)單的文檔類型:<!DOCTYPE html>,表示瀏覽器會(huì)按照標(biāo)準(zhǔn)模式解析。今天小編給大家?guī)?lái)了HTML5新特性之語(yǔ)義化標(biāo)簽,感興趣的朋友一起看看吧2017-10-31
- HTML5想必大家都很熟悉了,因?yàn)樘嗟拿襟w在討論這一技術(shù)。所以當(dāng)我們?cè)诿嬖嚽岸斯ぷ鞯臅r(shí)候,遇到html5相關(guān)的問(wèn)題一點(diǎn)也不意外,想要順利通過(guò)前端面試?下面這篇文章就來(lái)跟2017-09-05
- 這篇文章主要介紹了CSS3動(dòng)畫(huà)和HTML5新特性詳解,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-08-31