JavaScript全屏和退出全屏事件總結(jié)(附代碼)
代碼如下:
window.isflsgrn = false;//ie11以下是否進(jìn)入全屏標(biāo)志,true為全屏狀態(tài),false為非全屏狀態(tài)
window.ieIsfSceen = false;//ie11是否進(jìn)入全屏標(biāo)志,true為全屏狀態(tài),false為非全屏狀態(tài)
//跨瀏覽器返回當(dāng)前 document 是否進(jìn)入了可以請(qǐng)求全屏模式的狀態(tài)
function fullscreenEnable(){
var isFullscreen = document.fullscreenEnabled ||
window.fullScreen ||
document.mozFullscreenEnabled ||
document.webkitIsFullScreen;
return isFullscreen;
}
//全屏
var fScreen = function(){
var docElm = document.documentElement;
if (docElm.requestFullscreen) {
docElm.requestFullscreen();
}
else if (docElm.msRequestFullscreen) {
docElm.msRequestFullscreen();
ieIsfSceen = true;
}
else if (docElm.mozRequestFullScreen) {
docElm.mozRequestFullScreen();
}
else if (docElm.webkitRequestFullScreen) {
docElm.webkitRequestFullScreen();
}else {//對(duì)不支持全屏API瀏覽器的處理,隱藏不需要顯示的元素
window.parent.hideTopBottom();
isflsgrn = true;
$("#fsbutton").text("退出全屏");
}
}
//退出全屏
var cfScreen = function(){
if (document.exitFullscreen) {
document.exitFullscreen();
}
else if (document.msExitFullscreen) {
document.msExitFullscreen();
}
else if (document.mozCancelFullScreen) {
document.mozCancelFullScreen();
}
else if (document.webkitCancelFullScreen) {
document.webkitCancelFullScreen();
}else {
window.parent.showTopBottom();
isflsgrn = false;
$("#fsbutton").text("全屏");
}
}
//全屏按鈕點(diǎn)擊事件
$("#fsbutton").click(function(){
var isfScreen = fullscreenEnable();
if(!isfScreen && isflsgrn == false){
if (ieIsfSceen == true) {
document.msExitFullscreen();
ieIsfSceen = false;
return;
}
fScreen();
}else{
cfScreen();
}
})
//鍵盤操作
$(document).keydown(function (event) {
if(event.keyCode == 27 && ieIsfSceen == true){
ieIsfSceen = false;
}
});
//監(jiān)聽狀態(tài)變化
if (window.addEventListener) {
document.addEventListener('fullscreenchange', function(){
if($("#fsbutton").text() == "全屏"){
$("#fsbutton").text("退出全屏");
}else{
$("#fsbutton").text("全屏");
}
});
document.addEventListener('webkitfullscreenchange', function(){
if($("#fsbutton").text() == "全屏"){
$("#fsbutton").text("退出全屏");
}else{
$("#fsbutton").text("全屏");
}
});
document.addEventListener('mozfullscreenchange', function(){
if($("#fsbutton").text() == "全屏"){
$("#fsbutton").text("退出全屏");
}else{
$("#fsbutton").text("全屏");
}
});
document.addEventListener('MSFullscreenChange', function(){
if($("#fsbutton").text() == "全屏"){
$("#fsbutton").text("退出全屏");
}else{
$("#fsbutton").text("全屏");
}
});
}
值得注意的是 fullscreenEnabled 參數(shù),網(wǎng)上的說法不一,有的說是監(jiān)控瀏覽器是否進(jìn)入了可以請(qǐng)求全屏模式的狀態(tài),有的說只是一個(gè)判斷瀏覽器是否支持全屏的標(biāo)志,實(shí)際使用時(shí)也確實(shí)出現(xiàn)了問題,IE11不能識(shí)別這個(gè)屬性,需要自己?jiǎn)为?dú)設(shè)置一個(gè)標(biāo)記來控制IE11當(dāng)前是否為全屏狀態(tài)。
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來一定的幫助~如果有疑問大家可以留言交流,謝謝大家對(duì)腳本之家的支持!
相關(guān)文章
javascript中數(shù)組與對(duì)象的使用方法區(qū)別
數(shù)組(array)是按次序排列的一組值。JS其實(shí)沒有真正的數(shù)組,只是用對(duì)象模擬數(shù)組。本質(zhì)上,數(shù)組屬于一種特殊的對(duì)象。typeof運(yùn)算符會(huì)返回?cái)?shù)組的類型是object。在javascript中,數(shù)組又可以認(rèn)為是索引數(shù)組,即可以用整數(shù)來進(jìn)行索引。數(shù)組和對(duì)象在這種情況下非常接近。2022-12-12
Canvas實(shí)現(xiàn)動(dòng)態(tài)粒子文字效果的代碼示例
這篇文章主要介紹了如何用Canvas實(shí)現(xiàn)動(dòng)態(tài)粒子文字效果,文中有完整的代碼示例,文章通過代碼介紹的非常清楚,感興趣的小伙伴跟著小編一起來看看吧2023-08-08
js實(shí)現(xiàn)彈出框的拖拽效果實(shí)例代碼詳解
本文通過實(shí)例代碼給大家介紹了js實(shí)現(xiàn)彈出框的拖拽效果,代碼簡(jiǎn)單易懂,非常不錯(cuò),具有一定的參考借鑒價(jià)值 ,需要的朋友可以參考下2019-04-04
js實(shí)現(xiàn)手表表盤時(shí)鐘與圓周運(yùn)動(dòng)
這篇文章主要為大家詳細(xì)介紹了js實(shí)現(xiàn)手表表盤時(shí)鐘與圓周運(yùn)動(dòng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-09-09
適用于javascript開發(fā)者的Processing.js入門教程
這篇文章主要介紹了適用于javascript開發(fā)者的Processing.js入門教程,感興趣的小伙伴們可以參考一下2016-02-02
jquery中click等事件綁定及移除的幾種方法小結(jié)
這篇文章主要介紹了jquery中綁定事件與解綁事件是常用到的寫法,這里總結(jié)了幾種常見的綁定事件與解綁事件的方法,需要的朋友可以參考下2023-05-05
Js實(shí)現(xiàn)雙擊鼠標(biāo)自動(dòng)滾動(dòng)屏幕的示例代碼
這篇文章主要介紹了Js實(shí)現(xiàn)雙擊鼠標(biāo)自動(dòng)滾動(dòng)屏幕的示例代碼。需要的朋友可以過來參考下,希望對(duì)大家有所幫助2013-12-12

