HTML5全屏(Fullscreen)API詳細(xì)介紹
來源:易賢網(wǎng) 閱讀:1138 次 日期:2016-07-09 11:37:37
溫馨提示:易賢網(wǎng)小編為您整理了“HTML5全屏(Fullscreen)API詳細(xì)介紹”,方便廣大網(wǎng)友查閱!

這篇文章主要介紹了HTML5全屏(Fullscreen)API詳細(xì)介紹,本文給出了啟動(dòng)全屏模式和退出全屏模式代碼示例,同時(shí)講解了Fullscreen 屬性與事件,需要的朋友可以參考下

在越來越真實(shí)的web應(yīng)用程序中,JavaScript也變得越來越給力.

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

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

啟動(dòng)全屏模式

全屏API requestFullscreen方法在一些老的瀏覽器里面依然使用帶前綴形式的方法名,因此可能需要進(jìn)行檢測判斷:

(帶前綴,意思就是各個(gè)瀏覽器內(nèi)核不通用.)

代碼如下:

// 找到支持的方法, 使用需要全屏的 element 調(diào)用

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();

}

}

// 在支持全屏的瀏覽器中啟動(dòng)全屏

// 整個(gè)頁面

launchFullScreen(document.documentElement);

// 某個(gè)元素

launchFullScreen(document.getElementById("videoElement"));

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

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

退出全屏模式

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

代碼如下:

// 退出 fullscreen

function exitFullscreen() {

if(document.exitFullscreen) {

document.exitFullscreen();

} else if(document.mozExitFullScreen) {

document.mozExitFullScreen();

} else if(document.webkitExitFullscreen) {

document.webkitExitFullscreen();

}

}

// 調(diào)用退出全屏方法!

exitFullscreen();

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

Fullscreen 屬性與事件

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

1.document.fullscreenElement: 當(dāng)前處于全屏狀態(tài)的元素 element.

2.document.fullscreenEnabled: 標(biāo)記 fullscreen 當(dāng)前是否可用.

當(dāng)進(jìn)入/退出 全屏模式時(shí),會(huì)觸發(fā) fullscreenchange 事件:

代碼如下:

var fullscreenElement =

document.fullscreenEnabled

|| document.mozFullscreenElement

|| document.webkitFullscreenElement;

var fullscreenEnabled =

document.fullscreenEnabled

|| document.mozFullscreenEnabled

|| document.webkitFullscreenEnabled;

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

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需要一些特殊處理,所以在處理多媒體時(shí),你可能需要上面的代碼。

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

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

請記住這個(gè)很好的API吧 —— 在未來的某個(gè)時(shí)刻,它肯定會(huì)派上用場!

更多信息請查看網(wǎng)頁制作
易賢網(wǎng)手機(jī)網(wǎng)站地址:HTML5全屏(Fullscreen)API詳細(xì)介紹
由于各方面情況的不斷調(diào)整與變化,易賢網(wǎng)提供的所有考試信息和咨詢回復(fù)僅供參考,敬請考生以權(quán)威部門公布的正式信息和咨詢?yōu)闇?zhǔn)!
關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 加入群交流 | 手機(jī)站點(diǎn) | 投訴建議
工業(yè)和信息化部備案號(hào):滇ICP備2023014141號(hào)-1 云南省教育廳備案號(hào):云教ICP備0901021 滇公網(wǎng)安備53010202001879號(hào) 人力資源服務(wù)許可證:(云)人服證字(2023)第0102001523號(hào)
云南網(wǎng)警備案專用圖標(biāo)
聯(lián)系電話:0871-65317125(9:00—18:00) 獲取招聘考試信息及咨詢關(guān)注公眾號(hào):hfpxwx
咨詢QQ:526150442(9:00—18:00)版權(quán)所有:易賢網(wǎng)
云南網(wǎng)警報(bào)警專用圖標(biāo)