如今h5新功能、新標籤、新規範等很多,而且不斷完善中,各大瀏覽器商對它們的支持,也是相當給力。身為前端程式設計師,我覺得我們還是有必要積極關注並勇敢地加以實踐。接下來我將和各位分享一個特別好用的h5新特性(目前也不是特別新),輕鬆監聽任何App自帶的返回鍵,包括安卓機裡的物理返回鍵,從而實現項目開發中進一步的需求。
2、起因大概半年前接到pm一需求,用純h5實現多audio的播放、暫停、續播,頁面放至駕考寶典App中,與客戶端沒有任何的交互,所以與客戶端相關的js不需要引用。看起來這需求蠻簡單的嘛,雖然之前也沒做過類似的需求。不管三七二十一,擼起袖子就是乾。開始了學習之旅。
3.我這裡著重介紹下我具體是怎麼監聽任何App自帶的返回鍵,以及安卓機裡的實體返回鍵。那為什麼我要去監聽呢,這裡我有必要強調強調再強調。蘋果手機不管是微信、QQ、App,還是瀏覽器裡,涉及到audio、video,返回上一頁系統會自動暫停當前的播放的,但不是所有安卓機都可以。所以我們自己必須自訂監聽。很多朋友可能第一想法就是百度,然後出來的答案無非是這樣
pushHistory(); window.addEventListener(popstate, function(e) { alert(我監聽到了瀏覽器的返回按鈕事件啦);//根據自己的需求實現自己的功能}, false); function pushHistory() { var state = { title: title, url: # }; window.history.pushState(state, title, #); }
是不是很眼熟?然而關鍵需求不能完美實現,要這段程式碼有何用,當時我也是絞盡腦汁。直到經過大神好友指導,複製了這段程式碼
var hiddenProperty = 'hidden' in document ? 'hidden' : 'webkitHidden' in document ? 'webkitHidden' : 'mozHidden' in document ? 'mozHidden' : null;var visibilityChangeEvent> );var onVisibilityChange = function(){ if (!document[hiddenProperty]) { console.log('頁面非啟動'); }else{ console.log('頁面啟動') }}document.addEventListener(visibilityChangeEvent, onVisibilityChange);
所有問題都迎刃而解。
這段程式碼的原理我個人理解就是透過判斷使用者瀏覽的是否為當前頁,從而進行相關操作。
這是MDN相關連結:https://developer.mozilla.org/zh-CN/docs/Web/API/Document/hidden
並不是說真的可以透過JS監聽到App裡的自帶回傳鍵,甚至是安卓的實體回傳鍵,而是透過轉變思路,快速實現需求。希望這個特性能幫到各位。
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VeVb武林網。