溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何實現(xiàn)HTML5全屏API

發(fā)布時間:2021-09-28 11:37:55 來源:億速云 閱讀:104 作者:iii 欄目:web開發(fā)

這篇文章主要介紹“如何實現(xiàn)HTML5全屏API”,在日常操作中,相信很多人在如何實現(xiàn)HTML5全屏API問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”如何實現(xiàn)HTML5全屏API”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!

在越來越真實的web應用程序中,JavaScript也變得越來越給力.

FullScreen API 是一個新的JavaScript API,簡單而又強大. FullScreen 讓我們可以通過編程的方式來向用戶請求全屏顯示,如果交互完成,隨時可以退出全屏狀態(tài).

在線演示Demo:  Fullscreen API Example

(在此Demo中,可以Launch ,Hide ,以及Dump顯示相關屬性,可以通過chrome的控制臺查看日志信息.)

啟動全屏模式

全屏API requestFullscreen方法在一些老的瀏覽器里面依然使用帶前綴形式的方法名,因此可能需要進行檢測判斷:
(帶前綴,意思就是各個瀏覽器內核不通用.)

代碼如下:


// 找到支持的方法, 使用需要全屏的 element 調用  
function launchFullScreen(element) {  
 if(element.requestFullscreen) {  
   element.requestFullscreen();  
 } else if(element.mozRequestFullScreen) {  
   element.mozRequestFullScreen();  
 } else if(element.webkitRequestFullscreen) {  
   element.webkitRequestFullscreen();  
 } else if(element.msRequestFullscreen) {  
   element.msRequestFullscreen();  
 }  
}  
 
 
// 在支持全屏的瀏覽器中啟動全屏  
// 整個頁面  
launchFullScreen(document.documentElement);  
// 某個元素  
launchFullScreen(document.getElementById("videoElement"));  

將需要全屏顯示的DOM元素作為參數(shù),調用此方法即可讓window進入全屏狀態(tài),有時候可能需要用戶同意(瀏覽器自己和用戶交互),假若用戶拒絕,則可能出現(xiàn)各種不完全的全屏.

如果用戶同意進入全屏,那么工具欄以及其他瀏覽器組件會隱藏起來,使document框架的寬度和高度橫跨整個屏幕.

退出全屏模式

使用 exitFullscreen 方法可以使瀏覽器退出全屏,返回原先的布局. 該方法在一些老的瀏覽器上也是支持前綴方法.

代碼如下:


// 退出 fullscreen  
function exitFullscreen() {  
 if(document.exitFullscreen) {  
   document.exitFullscreen();  
 } else if(document.mozExitFullScreen) {  
   document.mozExitFullScreen();  
 } else if(document.webkitExitFullscreen) {  
   document.webkitExitFullscreen();  
 }  
}  
 
 
// 調用退出全屏方法!  
exitFullscreen();  


請注意: exitFullscreen 只能通過 document 對象調用 —— 而不是使用普通的 DOM element.

Fullscreen 屬性與事件

一個壞消息,到目前為止,全屏事件和方法依然是帶前綴的,好消息就是很快主流瀏覽器就會都支持。

1.document.fullscreenElement:  當前處于全屏狀態(tài)的元素 element.
2.document.fullscreenEnabled:  標記 fullscreen 當前是否可用.

當進入/退出 全屏模式時,會觸發(fā) fullscreenchange 事件:

代碼如下:


var fullscreenElement =  
   document.fullscreenEnabled  
   || document.mozFullscreenElement  
   || document.webkitFullscreenElement;  
var fullscreenEnabled =  
   document.fullscreenEnabled  
   || document.mozFullscreenEnabled  
   || document.webkitFullscreenEnabled;  


在初始化全屏方法時,可以探測需要監(jiān)聽哪一個事件.

Fullscreen CSS

瀏覽器提供了一些有用的 fullscreen CSS 控制規(guī)則:

代碼如下:


/* html */  
:-webkit-full-screen {  
 /* properties */  
}  
:-moz-fullscreen {  
 /* properties */  
}  
 
 
:fullscreen {  
 /* properties */  
}  
 
 
/* deeper elements */  
:-webkit-full-screen video {  
 width: 100%;  
 height: 100%;  
}  
 
 
/* styling the backdrop */  
::backdrop {  
 /* properties */  
}  


在某些情況下,WebKit需要一些特殊處理,所以在處理多媒體時,你可能需要上面的代碼。

我認為 Fullscreen API 超級簡單,超級有用. 我首次見到這個 API 是在一個名為 MDN's BananaBread demo 的全客戶端第一人稱射擊游戲, 這真是一個使用全屏模式的絕佳案例。

全屏API提供了進入和退出全屏模式的方式,并提供相應的事件來監(jiān)測全屏狀態(tài)的改變,所以各方面都連貫起來了.

請記住這個很好的API吧 —— 在未來的某個時刻,它肯定會派上用場!

到此,關于“如何實現(xiàn)HTML5全屏API”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續(xù)學習更多相關知識,請繼續(xù)關注億速云網站,小編會繼續(xù)努力為大家?guī)砀鄬嵱玫奈恼拢?/p>

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經查實,將立刻刪除涉嫌侵權內容。

AI