第一次看到应用 Fullscreen API 全屏显示网页,是 FaceBook 中的照片放大。作为一个比较新的 API,目前只有 Safari、Chrome 和 FireFox 三种浏览器支持该特性。因为尚未发布正式版的标准,所以必须使用浏览器特定的方法,也就是应用添加前缀(webit/moz)的方法。
这个 API 不仅能够使整个页面全屏显示,也可以使页面中的某个元素全屏显示。它的设计初衷是为了全屏显示 HTML5 视频和游戏,以便更全面的替代 flash 功能。尽管还有很多有待完善的地方,但是作为一个新的浏览器特性,在某些地方还是能够极大地增强用户体验。

1. 标准调用方式

要对某个元素使用全屏特效,标准的流程是:

  1. 调用这个元素对象的 requestFullscreen() 方法;

  2. 浏览器将元素全屏显示,改变相关的属性值,然后触发 document 的 fullscreenchange 事件;

  3. 退出全屏时有两种方式,一种是默认的按 ESC 键退出,一种是调用 document 的 exitFullscreen() 方法;

  4. 浏览器将元素退出全屏显示,改变相关属性值,再次触发 fullscreenchange 方法。

浏览器在改变全屏状态时修改的相关属性,是指修改当前全屏状态有否、全屏显示的元素对象,这些属性都是只读的。

浏览器触发 fullscreenchange 事件,默认不做任何处理,内部的处理函数需要编程人员自行判断当前全屏状态后,进行相应处理。
对应的,规范中还添加了一个 :fullscreen 伪类,对当前全屏的元素进行样式定义。

2. 封装API

Fullscreen 目前只有两个方法:进入全屏、退出全屏,三个属性(全部是只读的):是否支持全屏、当前全屏状态、当前全屏元素,以及一个在全屏状态改变时触发的事件( Using full-screen mode 中提到还有一个 fullscreenerror,但是我没有测试出如何才能触发这个事件 )。与 W3 草案 相比,FireFox 的实现更符合标准,而 webkit 内核浏览器中的方法则要自我很多。
所有的方法和属性中,只有 requestFullscreen() 是 element 对象的方法,其他全部是 document 对象所有的方法和属性。

2.1 进入全屏:element.requestFullscreen()

将 element 全屏显示。webkit内核浏览器和Firefox表现不同,前者只要求element是DOM元素即可,后者则要求DOM必须是文档流中的元素,比较严格,否则不能全屏显示。
出于安全考虑,全屏状态下默认是不允许用户输入的。webkit 内核浏览器会阻止除方向键、控制键之外的键盘输入,FireFox 会在输入时发出要求用户退出全屏状态的提示。前者可以通过在方法 webkitRequestFullScreen() 中传入参数 Element.LLOW_KEYBOARD_INPUT 允许用户输入,但 Safari 一旦传入该参数,整个 Fullscreen 功能都会坏掉(这应该是 Safari 的一个bug);后者直接就可以输入,除了有个烦人的提示。

webkit 浏览器中可以通过只读属性 document.webkitFullScreenKeyboardInputAllowed 查看当前是否允许全屏状态下的输入。

/**
* 标准化 requestFullscreen 方法
* @param {DOM} elem 要全屏显示的元素(webkit下只要是DOM即可,Firefox下必须是文档中的DOM元素)
*/
function requestFullscreen( elem ) {
if (elem.requestFullscreen) {
elem.requestFullscreen();
}
else if (elem.webkitRequestFullScreen) {
// 对 Chrome 特殊处理,
// 参数 Element.ALLOW_KEYBOARD_INPUT 使全屏状态中可以键盘输入。
if ( window.navigator.userAgent.toUpperCase().indexOf( 'CHROME' ) >= 0 ) {
elem.webkitRequestFullScreen( Element.ALLOW_KEYBOARD_INPUT );
}
// Safari 浏览器中,如果方法内有参数,则 Fullscreen 功能不可用。
else {
elem.webkitRequestFullScreen();
}
}
else if (elem.mozRequestFullScreen) {
elem.mozRequestFullScreen();
}
}

2.2 退出全屏:document.exitFullscreen()

从全屏状态中退出。目前实现的方法都是 cancelFullScreen() ,而不是标准的 exitFullscreen()。

/**
* 标准化 exitFullscreen 方法
*/
function exitFullscreen() {
if (document.exitFullscreen) {
document.exitFullscreen();
}
else if (document.webkitCancelFullScreen) {
document.webkitCancelFullScreen();
}
else if (document.mozCancelFullScreen) {
document.mozCancelFullScreen();
}
}

2.3 浏览器是否支持全屏:document.fullscreenEnabled

通过该属性的boolean值判断浏览器是支持 Fullscreen 功能。
webkit 内核的浏览器目前还没有该属性,因此只能通过能力判定来判断是否支持全屏显示功能。Firefox 已经有了对应的属性定义。

/* 标准化 fullscreenEnabled 属性 (只读) */
document.fullscreenEnabled = ( function() {
var doc = document.documentElement;
return ( 'requestFullscreen' in doc ) ||
( 'webkitRequestFullScreen' in doc ) ||
// 对Firefox除了能力判断,还加上了属性判断
( 'mozRequestFullScreen' in doc && document.mozFullScreenEnabled ) ||
false;
} )();

2.4 :document.fullscreenElement

当前全屏显示的DOM元素。

/**
* 标准化 fullscreenElement 属性 (只读)
* 以同名方法替代
*/
function fullscreenElement() {
return document.fullscreenElement ||
document.webkitCurrentFullScreenElement ||
document.mozFullScreenElement ||
null;
}

2.5 当前全屏状态:document.fullscreen

该属性并未在2012/6/3的 w3草案 中出现,但在Using full-screen mode一文中介绍了该属性。其值为 boolean 类型,判断当前文档的全屏状态。

如果最终去掉这个判断全屏状态的属性,我们仍然可以通过 document.fullscreenElement 的值是否为 null 来判断全屏与否

/**
* 标准化 fullscreen 属性 (只读)
* 以同名方法替代
*/
function fullscreen() {
return document.fullscreen ||
document.webkitIsFullScreen ||
document.mozFullScreen ||
false;
}

2.6 全屏状态改变事件:fullscreenchange

该事件要绑定在 document 上,该事件仅在全屏状态改变时触发,默认没有任何动作。

/* 绑定 document 的 fullscreenchange 事件 */
document.addEventListener(
'fullscreenchange', // webkitfullscreenchange/mozfullscreenchange
function( evt ){
//todo 全屏状态改变时的时间处理。
//默认不会有任何处理,需要自己判断当前屏幕全屏与否,做出相应处理。
},
false
); /* 如果使用 jQuery : */
$( document ).bind(
'fullscreenchange webkitfullscreenchange mozfullscreenchange',
function(){
//todo code
}
);

3. 全屏样式设置

标准中,通过 :fullscreen 伪类对全屏的元素进行样式定义。

默认情况下,浏览器只会简单地将元素设置为全屏显示。如果该元素全屏后,高度比屏幕还高,超出的部分将会被隐藏。为了将超出部分可以滚动显示,最顶层全屏显示的元素要特别设置:

position : fixed;
top : 0;
left : 0;
width : 100%;
height : 100%;
overflow : auto;

一般情况下,要全屏显示的元素是不能像上面这样设置的。那么我们可以变通下,设置一个 <div/>,包围要全屏的元素,然后将这个 <div/> 设置为全屏,上面的样式定义就可以定义在这个 <div/> 上,相应的,:fullscreen 将会作用在这个 <div/> 上。这样,过长的元素就可以在这个包围层内滚动显示。

4. 特别注意

  • 目前 FireFox 10、Safari 5.1+、Chrome 15+ 支持全屏

  • 可以使任意元素全屏显示,不只是整个页面

  • 全屏只能从事件触发(用户操作),而不能用代码直接触发

  • 全屏状态下,webkit 内核浏览器默认会阻止除方向键、控制键之外的键盘输入,FireFox 会在输入时发出退出全屏状态提示。处理方法在 封装API 部分有说明。

下面是实际中遇到的需要注意的地方:

  • 全屏状态切换需要时间。执行 requestFullscreen() 后,并不会立即进入全屏状态,对应的全屏属性不会立即更改,而是有一个执行时间。因此,只能在 fullscreenchange 事件触发后才代表进入了全屏状态。但是在 fullscreenchange 事件中调用 $(window).width() 并不总能得到全屏的尺寸,这个现象很奇怪。如果需要屏幕尺寸,可以通过 window.screen.width 来获得。

  • 涉及修改DOM文档须注意代码位置。当用 <div/> 包围要全屏显示的元素时,这段 javascript 代码不应该在要全屏显示的元素内部,否则这段代码会被执行两遍,而且第二遍不会在断点中被监视到,原因将在后文详细描述。

  • ESC 键不同系统功能不同。目前发现点击 ESC 退出全屏时,mac系统不会再额外触发键盘事件,但是win7系统下出发 fullscreenchange 事件后还会立马触发键盘事件,因此如果还有不希望被触发的键盘事件,可以设置一个监视变量,在很短时间后再修改监视变量,以错过这个立马执行的时间。

5. 未涉及功能

  • iframe 元素的 allowfullscreen 属性

  • ::backdrop 伪类

  • 具体其他细节可以参考 W3 草案

6. 结语

Fullscreen API 毕竟目前只是草案,尚未形成正式的标准,况且各个浏览器的实现情况也不完全相同,甚至细节上的实现差别更可能引发预想不到的问题。但作为渐进增强方式使用的新功能,能够极大的增强用户体验。仍要根据规范的完善,不断改进我们的代码。
详细代码可以参考:https://github.com/calefy/calefy.github.com/blob/master/js/Fullscreen.js

参考

    1. W3 草案 2012/6/3版

    2. Using full-screen mode

    3. Enhance Your Website with the FullScreen API

    4. Using the Fullscreen API in web browsers

    5. 代码参考 jQuery Fullscreen 插件本文转载自http://hao.jser.com/archive/10864/

全屏显示网页FULLSCREEN API的更多相关文章

  1. 第89天:HTML5中 访问历史、全屏和网页存储API

    一.访问历史 API 通过history对象实现前进.后退和刷新之类的操作 history新增的两个方法history.replaceState()和history.pushState()方法属于HT ...

  2. Fullscreen API 全屏显示网页

    可参考文档:http://blog.csdn.net/tywali/article/details/8623938 脚本代码 <script type="text/javascript ...

  3. JavaScript:让浏览器全屏显示

    并不是所有人都会按F11让浏览器全屏显示~~~ 一.直接上代码 <!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xh ...

  4. 【温故而知新-Javascript】窗口效果 (全屏显示窗口、定时关闭窗口)

    1.全屏显示窗口 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://ww ...

  5. echarts 饼图 + 全屏显示

    效果图: 代码: <!DOCTYPE html> <html lang="en"> <head> <meta charset=" ...

  6. 在VC++6.0开发中实现全屏显示

    全屏显示是一些应用软件程序必不可少的功能.比如在用VC++编辑工程源文件或编辑对话框等资源时,选择菜单“View\Full Screen”,即可进入全屏显示状态,按“Esc”键后会退出全屏显示状态. ...

  7. Android 全屏显示的方法(不包含状态栏)

    我们都知道在Android中某些功能的实现往往有两种方法:一种是在xml文件中设置相应属性,另一种是用代码实现.同样Android实现全屏显示也可以通过这两种方法实现: 1.在AndroidManif ...

  8. Android 全屏显示

    Android全屏显示: @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInst ...

  9. Qt on Android:让 Qt Widgets 和 Qt Quick 应用全屏显示

    Android 系统版本号非常多,较新的 4.4 ,较老的 2.3 ,都有人用. Qt on Android 开发的 Android 应用.默认在 Android 设备上是非全屏的. 而有些应用的需求 ...

随机推荐

  1. 配置Tomcat中的Context元素中的中文问题

    发布一个名叫helloapp的web应用,helloapp位于D:\我\helloapp.发布的方式是通过配置<CATALINA_HOME>/conf/Catalina/localhost ...

  2. ie textarea不支持maxlength textarea限制长度

    //ie textarea不支持maxlength $('#verify_note').bind('input propertychange', function() { if (this.value ...

  3. MAC OS中使用ll,la命令

    在linux下习惯了使用ll.la等ls别名 用mac os发现没有这样的命令,很不方便. 其实只要在用户目录下建立一个脚本“.bash_profile”,并输入以下内容即可:alias ll='ls ...

  4. 高可用集群(HA)之DRBD原理和基础配置

    目录 1.工作原理图 2.用户空间工具 3.工作模式 4.实现主备故障自动切换 5.所需软件 6.配置文件 7.详细配置     1.配置通用属性信息     2.定义一个资源     3.初始化资源 ...

  5. NET Core的知识

    NET Core的基础知识补遗 阅读目录 前言 在.NET Core之前 在.NET Core起步 .NET Core 1.0 .NET平台 开发环境 FAQ 写在最后 回到目录 前言 .NET Co ...

  6. Myeclipse6.5配置反编译插件

    PS:jad.exe位置与Myeclipse6.5安装目录平行

  7. [原]bochs+dos6.22汇编环境

    1.下载安装bochs 下载MS-DOS http://files.cnblogs.com/allbymyself/DOS6.22.rar 下载Masm5.0 2.bochs配置 1)安装目录下的bx ...

  8. 使用fragment,Pad手机共用一套代码

    项目代码结构: 1:MainActivity.java package com.example.fgtest; import android.app.Activity; import android. ...

  9. Yslow-23条规则编辑

    1. 减少HTTP请求次数 合并图片.CSS.JS,改进首次访问用户等待时间.   2. 使用CDN 就近缓存==>智能路由==>负载均衡==>WSA全站动态加速   3. 避免空的 ...

  10. arcgis api for silverlight使用google map等多个在线地图

    原文 http://blog.csdn.net/leesmn/article/details/6820245 无可否认,google map实在是很漂亮.可惜对于使用arcgis api for si ...