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

HTML5全屏(Fullscreen)API詳細(xì)介紹

  發(fā)布時(shí)間:2015-04-24 15:49:31   作者:佚名   我要評(píng)論
這篇文章主要介紹了HTML5全屏(Fullscreen)API詳細(xì)介紹,本文給出了啟動(dòng)全屏模式和退出全屏模式代碼示例,同時(shí)講解了Fullscreen 屬性與事件,需要的朋友可以參考下

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

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

在線(xiàn)演示Demo:  Fullscreen API Example

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

啟動(dòng)全屏模式

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

復(fù)制代碼
代碼如下:

// 找到支持的方法, 使用需要全屏的 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è)頁(yè)面
launchFullScreen(document.documentElement);
// 某個(gè)元素
launchFullScreen(document.getElementById("videoElement"));

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

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

退出全屏模式

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

復(fù)制代碼
代碼如下:

// 退出 fullscreen
function exitFullscreen() {
if(document.exitFullscreen) {
document.exitFullscreen();
} else if(document.mozExitFullScreen) {
document.mozExitFullScreen();
} else if(document.webkitExitFullscreen) {
document.webkitExitFullscreen();
}
}


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

請(qǐng)注意: exitFullscreen 只能通過(guò) document 對(duì)象調(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 事件:


復(fù)制代碼
代碼如下:

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

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

Fullscreen CSS

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

復(fù)制代碼
代碼如下:

/* 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í)簡(jiǎn)單,超級(jí)有用. 我首次見(jiàn)到這個(gè) API 是在一個(gè)名為 的全客戶(hù)端第一人稱(chēng)射擊游戲, 這真是一個(gè)使用全屏模式的絕佳案例。

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

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

相關(guān)文章

  • HTML5中的Microdata與歷史記錄管理詳解

    Microdata作為HTML5新增的一個(gè)特性,它允許開(kāi)發(fā)者在HTML文檔中添加更多的語(yǔ)義信息,以便于搜索引擎和瀏覽器更好地理解頁(yè)面內(nèi)容,本文將探討HTML5中Microdata的使用方法以及
    2025-04-21
  • HTML5表格語(yǔ)法格式詳解

    在HTML語(yǔ)法中,表格主要通過(guò)< table >、< tr >和< td >3個(gè)標(biāo)簽構(gòu)成,本文通過(guò)實(shí)例代碼講解HTML5表格語(yǔ)法格式,感興趣的朋友一起看看吧
    2025-04-21
  • html5的響應(yīng)式布局的方法示例詳解

    這篇文章主要介紹了HTML5中使用媒體查詢(xún)和Flexbox進(jìn)行響應(yīng)式布局的方法,簡(jiǎn)要介紹了CSS Grid布局的基礎(chǔ)知識(shí)和如何實(shí)現(xiàn)自動(dòng)換行的網(wǎng)格布局,感興趣的朋友一起看看吧
    2025-04-21
  • 基于Canvas的Html5多時(shí)區(qū)動(dòng)態(tài)時(shí)鐘實(shí)戰(zhàn)代碼

    本文介紹了如何使用Canvas在HTML5上實(shí)現(xiàn)一個(gè)多時(shí)區(qū)動(dòng)態(tài)時(shí)鐘的web展示,通過(guò)Canvas的API,可以繪制出6個(gè)不同城市的時(shí)鐘,并且這些時(shí)鐘可以動(dòng)態(tài)轉(zhuǎn)動(dòng),每個(gè)時(shí)鐘上都會(huì)標(biāo)注出對(duì)應(yīng)的
    2025-03-11
  • HTML5 data-*自定義數(shù)據(jù)屬性的示例代碼

    HTML5的自定義數(shù)據(jù)屬性(data-*)提供了一種標(biāo)準(zhǔn)化的方法在HTML元素上存儲(chǔ)額外信息,可以通過(guò)JavaScript訪(fǎng)問(wèn)、修改和在CSS中使用,文章還介紹了高級(jí)用法,如存儲(chǔ)JSON數(shù)據(jù)、事
    2025-03-11
  • HTML5中下拉框<select>標(biāo)簽的屬性和樣式詳解

    在HTML5中,下拉框(<select>標(biāo)簽)作為表單的重要組成部分,為用戶(hù)提供了一個(gè)從預(yù)定義選項(xiàng)中選擇值的方式,本文將深入探討<select>標(biāo)簽的屬性、樣式,并重點(diǎn)介
    2025-02-27
  • HTML5 Input 日期選擇器詳解

    本文介紹了HTML5InputDatePicker對(duì)象表示HTML``元素,是HTML5中的新對(duì)象,介紹了日期、周、月份、時(shí)間、日期+時(shí)間、本地日期時(shí)間等不同類(lèi)型的日期選擇器,感興趣的朋友一起看
    2025-02-17
  • HTML5超鏈接和圖片基礎(chǔ)用法詳解

    本文介紹了HTML5中的超鏈接、相對(duì)路徑和圖片的使用方法,超鏈接可以創(chuàng)建指向另一個(gè)文檔或頁(yè)面內(nèi)部書(shū)簽的鏈接,相對(duì)路徑用于在同一服務(wù)器內(nèi)部跳轉(zhuǎn)頁(yè)面,圖片標(biāo)簽用于引入外部圖
    2025-02-17
  • HTML5超鏈接的創(chuàng)建方法

    本文介紹了HTML5超鏈接的創(chuàng)建方法,包括基本語(yǔ)法、創(chuàng)建圖像超鏈接的邊框去除方法以及錨點(diǎn)鏈接的使用,還討論了超鏈接的四種不同狀態(tài)(link、visited、hover、active)的CSS樣
    2025-02-17
  • HTML5使用details標(biāo)簽:展開(kāi)/收縮信息

    最近看一些技術(shù)網(wǎng)站發(fā)現(xiàn)了details 標(biāo)簽的妙用,這個(gè)不用js即可實(shí)現(xiàn)展開(kāi)/收縮信息,很方便用來(lái)讓用戶(hù)先才答案,然后下面點(diǎn)擊再給出答案的效果,這里就為大家簡(jiǎn)單介紹一下,
    2024-11-03

最新評(píng)論