使用h5新特性,輕鬆監聽任何App自帶返回鍵
1、前言
如今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 = 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監聽到App裡的自帶返回鍵,甚至安卓的物理返回鍵,而是通過轉變思路,快速實現需求。希望這個特效能幫到各位。
END
相關文章
- H5-監聽任何安卓機、App自帶的物理返回鍵H5安卓APP
- H5頁面監聽Android物理返回鍵H5Android
- web app 中物理返回鍵的監聽WebAPP
- android PopupWindow監聽返回鍵無效Android
- 帶你輕鬆上手Mac快捷鍵使用小技巧!Mac
- h5監聽手機鍵盤彈起H5
- Flutter監聽路由返回Flutter路由
- uniapp打包成apk,監聽安卓手機的返回鍵APPAPK安卓
- h5 storage事件監聽H5事件
- 安卓使用物理鍵監聽器安卓
- iOS 輕鬆使用 App 資料統計iOSAPP
- 帶你輕鬆瞭解C# Lock 關鍵字C#
- 官方帶隊實測,階梯式解鎖飛槳框架3.0能力新特性,輕鬆上手!框架
- 監聽鍵盤事件事件
- JS監聽手機物理返回鍵(及IOS微信端的bug)JSiOS
- Android Home鍵、鎖屏鍵監聽Android
- 移動端h5監聽瀏覽器返回操作(目前在react專案中用到)H5瀏覽器React
- python pynput監聽鍵盤Python
- flutter中監聽鍵盤Flutter
- [譯] 輕鬆釋出私有 AppAPP
- java鍵盤監聽之視窗監聽的實現Java
- 十個vim快捷鍵,讓你的使用更輕鬆
- 帶你輕鬆使用Hyperf玩轉Grpc(一)環境搭建RPC
- MySQL 8 新特性之自增主鍵的持久化MySql持久化
- 帶你十天輕鬆搞定 Go 微服務系列(八、服務監控)Go微服務
- 輕輕鬆鬆帶你入門Android Jetpack(含Jetpack Compose),容易肝不難!AndroidJetpack
- Windows 2003自帶效能監控工具的使用Windows
- AndroidStudio點選兩次返回鍵,退出APPAndroidAPP
- AndroidTV開發中所有的遙控器按鍵監聽及注意事項,新增home鍵監聽Android
- 輕鬆使用Aspire rabbitmq frameworkMQFramework
- 使用Spring JDBC新增記錄如何返回自增主鍵值SpringJDBC
- Echarts 監聽滑鼠右鍵或者雙擊Echarts
- 監控神器:Prometheus 輕鬆入門,真香!(上篇)Prometheus
- 監控神器:Prometheus 輕鬆入門,真香!(下篇)Prometheus
- IntelliJ IDEA mac快捷鍵,輕鬆擺脫滑鼠!IntelliJIdeaMac
- 輕鬆搞定專案流程自動化
- 使用Databinding輕鬆快速打造仿攜程app篩選控制元件(三)APP控制元件
- 使用Databinding輕鬆快速打造仿攜程app篩選控制元件(二)APP控制元件