欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

  發(fā)布時間:2018-03-13 15:42:34   作者:WckY   我要評論
這篇文章主要介紹了使用html5新特性輕松監(jiān)聽任何App自帶返回鍵的示例的相關資料,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

1、前言

如今h5新特性、新標簽、新規(guī)范等有很多,而且正在不斷完善中,各大瀏覽器商對它們的支持,也是相當給力。作為前端程序員,我覺得我們還是有必要積極關注并勇敢地加以實踐。接下來我將和各位分享一個特別好用的h5新特性(目前也不是特別新),輕松監(jiān)聽任何App自帶的返回鍵,包括安卓機里的物理返回鍵,從而實現項目開發(fā)中進一步的需求。

2、起因

大概半年前接到pm一需求,用純h5實現多audio的播放、暫停、續(xù)播,頁面放至駕考寶典App中,與客戶端沒有任何的交互,所以與客戶端相關的js不需要引用??瓷先ミ@需求挺簡單的嘛,雖然之前也沒做過類似的需求。不管三七二十一,擼起袖子就是干。開始了學習之旅。

3、我這里著重介紹下我具體是怎么監(jiān)聽任何App自帶的返回鍵,以及安卓機里的物理返回鍵。

那為什么我要去監(jiān)聽呢,這里我有必要強調強調再強調。蘋果手機不管是微信、QQ、App,還是瀏覽器里,涉及到audio、video,返回上一頁系統(tǒng)會自動暫停當前的播放的,但不是所有安卓機都可以。所以我們自己必須自定義監(jiān)聽。很多朋友可能第一想法就是百度,然后出來的答案無非是這樣

pushHistory(); 
window.addEventListener("popstate", function(e) { 
    alert("我監(jiān)聽到了瀏覽器的返回按鈕事件啦");//根據自己的需求實現自己的功能 
}, 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 = hiddenProperty.replace(/hidden/i, 'visibilitychange');
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監(jiān)聽到App里的自帶返回鍵,甚至安卓的物理返回鍵,而是通過轉變思路,快速實現需求。希望這個特性能幫到各位。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • css3實現動畫的三種方式

    這篇文章主要介紹了css3實現動畫的三種方式,幫助大家更好的理解和學習css3,感興趣的朋友可以了解下
    2020-08-24
  • 如何使用css3實現一個類在線直播的隊列動畫的示例代碼

    這篇文章主要介紹了如何使用css3實現一個類在線直播的隊列動畫的示例代碼,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下
    2020-06-17
  • html5新特性與用法大全

    有好多小伙伴私聊我問我html5新特性 和用法,下面我給大家具體介紹一下html5都新加了哪些新特性,感興趣的朋友跟隨腳本之家小編一起看看吧
    2018-09-13
  • HTML5新特性之type=file文件上傳功能

    這篇文章主要介紹了HTML5新特性之type=file文件上傳功能,需要的朋友可以參考下
    2018-02-02
  • HTML5新特性之語義化標簽

    HTML5 只有一個簡單的文檔類型:<!DOCTYPE html>,表示瀏覽器會按照標準模式解析。今天小編給大家?guī)砹薍TML5新特性之語義化標簽,感興趣的朋友一起看看吧
    2017-10-31
  • 前端面試必備之html5的新特性

    HTML5想必大家都很熟悉了,因為太多的媒體在討論這一技術。所以當我們在面試前端工作的時候,遇到html5相關的問題一點也不意外,想要順利通過前端面試?下面這篇文章就來跟
    2017-09-05
  • CSS3動畫和HTML5新特性詳解

    這篇文章主要介紹了CSS3動畫和HTML5新特性詳解,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-08-31

最新評論