彩世界平台-彩世界时时app-彩世界开奖app苹果下载

热门关键词: 彩世界平台,彩世界时时app,彩世界开奖app苹果下载

您的位置:彩世界平台 > 新闻动态 > 彩世界平台杂谈:HTML 5页面可视性API

彩世界平台杂谈:HTML 5页面可视性API

发布时间:2019-10-05 09:25编辑:新闻动态浏览(134)

    HTML5中与页面显示相关的API

    2015/05/15 · HTML5 · HTML5

    原文出处: 涂根华的博客   

    在HTML5中,增加了2个与页面显示相关的API,分别是Page Visibility API与Fullscreen API; 作用分别如下:

    Page Visibility API  是指当页面变为最小化状态或者用户将浏览器标签切换到其他标签时会触发。

    Fullscreen API 是将页面整体或页面中某个局部区域设为全屏。

    Page Visibility API的使用场合如下:

    1. 一个应用程序中具有多幅图片的幻灯片式的连续播放功能,当页面变为不可见状态(最小化状态或者将用户浏览器标签切换到其他标签时),图片停止播放,当页面变为可见状态时,图片继续播放。
    2. 在一个实时显示服务器端信息的应用程序中,当页面处于不可见状态(最小化状态或者将用户浏览器标签切换到其他标签时),停止定期向服务器端请求数据的处理,当页面变为可见状态,继续执行定期向服务器端请求数据的处理。
    3. 在一个具有播放视频功能的应用程序中,当页面处于不可见状态(最小化状态或者将用户浏览器标签切换到其他标签时),暂停播放视频,当页面变为可见状态时,继续播放视频。

    浏览器支持程度:Firefox10+,chrome14+,IE10+;

    实现Page Visibility API

    在使用Page Visibility API时,我们首先需要判断当前用户所使用的浏览器以及该浏览器是否支持。代码如下判断:

    JavaScript

    if(typeof document.hidden !== 'undefined') { hidden = 'hidden'; visibilityChange = 'visibilitychange'; }else if(typeof document.mozHidden !== 'undefined') { hidden = 'mozHidden'; visibilityChange = 'mozvisibilitychange'; }else if(typeof document.msHidden !== 'undefined') { hidden = 'msHidden'; visibilityChange = 'msvisibilitychange'; }else if(typeof document.webkitHidden !== 'undefined') { hidden = 'webkitHidden'; visibilityChange = 'webkitvisibilitychange'; }

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    if(typeof document.hidden !== 'undefined') {
        hidden = 'hidden';
        visibilityChange = 'visibilitychange';
    }else if(typeof document.mozHidden !== 'undefined') {
        hidden = 'mozHidden';
        visibilityChange = 'mozvisibilitychange';
    }else if(typeof document.msHidden !== 'undefined') {
        hidden = 'msHidden';
        visibilityChange = 'msvisibilitychange';
    }else if(typeof document.webkitHidden !== 'undefined') {        
        hidden = 'webkitHidden';
        visibilityChange = 'webkitvisibilitychange';
    }

    如上,在Page Visibility  API中,可以通过document对象的hidden属性值来判断页面是否处于可见状态,当页面处于可见状态时属性值为false,当页面处于不可见状态时属性值为true。

    在Page Visibility中,可以通过document对象的visibilityState属性值来判断页面的可见状态。该属性值为一个字符串,其含义如下所示:

        visible: 页面内容部分可见,当前页面位于用户正在查看的浏览器标签窗口中,且浏览器窗口未被最小化。

        hidden: 页面内容对用户不可见。当前页面不在用户正在查看的浏览器标签窗口中,或浏览器窗口已被最小化。

        prerender: 页面内容已被预渲染,但是对用户不可见。

    现在我们来看一个demo,页面中有一个video元素与一个”播放”按钮,用户单击”播放”按钮时 按钮文字变为 ’暂停”,同时开始播放video元素的视频,当页面变为最小化状态或用户浏览器标签切换到其他标签时候,视频被暂停播放,当页面恢复正常状态或用户将浏览器标签切回页面所在标签时,视频继续播放。

    HTML代码如下:

    JavaScript

    <video id="videoElement" controls width=640 height=360 autoplay> <source src="Wildlife/Wildlife.ogv" type='video/ogg; codecs="theora, vorbis"'/> <source src="Wildlife/Wildlife.webm" type='video/webm' > <source src="Wildlife/Wildlife.mp4" type='video/mp4'> </video> <button id="btnPlay" onclick="PlayOrPause()">播放</button> <div style="height:1500px;"></div>

    1
    2
    3
    4
    5
    6
    7
    <video id="videoElement" controls width=640 height=360 autoplay>
        <source src="Wildlife/Wildlife.ogv" type='video/ogg; codecs="theora, vorbis"'/>
        <source src="Wildlife/Wildlife.webm" type='video/webm' >
        <source src="Wildlife/Wildlife.mp4" type='video/mp4'>
    </video>
    <button id="btnPlay" onclick="PlayOrPause()">播放</button>
    <div style="height:1500px;"></div>

    JS代码如下:

    JavaScript

    var hidden, visibilityChange, videoElement; if(typeof document.hidden !== 'undefined') { hidden = 'hidden'; visibilityChange = 'visibilitychange'; }else if(typeof document.mozHidden !== 'undefined') { hidden = 'mozHidden'; visibilityChange = 'mozvisibilitychange'; }else if(typeof document.msHidden !== 'undefined') { hidden = 'msHidden'; visibilityChange = 'msvisibilitychange'; }else if(typeof document.webkitHidden !== 'undefined') { hidden = 'webkitHidden'; visibilityChange = 'webkitvisibilitychange'; } document.addEventListener(visibilityChange,handle,false); videoElement = document.getElementById("videoElement"); videoElement.addEventListener('ended',videoEnded,false); videoElement.addEventListener('play',videoPlay,false); videoElement.addEventListener('pause',videoPause,false); // 如果页面变为不可见状态 则暂停视频播放 // 如果页面变为可见状态,则继续视频播放 function handle() { // 通过visibilityState属性值判断页面的可见状态 console.log(document.visibilityState); if(document[hidden]) { videoElement.pause(); }else { videoElement.play(); } } // 播放视频 function play() { videoElement.play(); } // 暂停播放 function pause() { videoElement.pause(); } function PlayOrPause() { if(videoElement.paused) { videoElement.play(); }else { videoElement.pause(); } } function videoEnded(e) { videoElement.currentTime = 0; this.pause(); } function videoPlay(e) { var btnPlay = document.getElementById("btnPlay"); btnPlay.innerHTML = "暂停"; } function videoPause(e) { var btnPlay = document.getElementById("btnPlay"); btnPlay.innerHTML = "播放"; }

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    var hidden,
    visibilityChange,
    videoElement;
    if(typeof document.hidden !== 'undefined') {
        hidden = 'hidden';
        visibilityChange = 'visibilitychange';
    }else if(typeof document.mozHidden !== 'undefined') {
        hidden = 'mozHidden';
        visibilityChange = 'mozvisibilitychange';
    }else if(typeof document.msHidden !== 'undefined') {
        hidden = 'msHidden';
        visibilityChange = 'msvisibilitychange';
    }else if(typeof document.webkitHidden !== 'undefined') {
        hidden = 'webkitHidden';
        visibilityChange = 'webkitvisibilitychange';
    }
    document.addEventListener(visibilityChange,handle,false);
    videoElement = document.getElementById("videoElement");
    videoElement.addEventListener('ended',videoEnded,false);
    videoElement.addEventListener('play',videoPlay,false);
    videoElement.addEventListener('pause',videoPause,false);
    // 如果页面变为不可见状态 则暂停视频播放
    // 如果页面变为可见状态,则继续视频播放
    function handle() {
        // 通过visibilityState属性值判断页面的可见状态
        console.log(document.visibilityState);
        if(document[hidden]) {
            videoElement.pause();    
        }else {
            videoElement.play();
        }
    }
    // 播放视频
    function play() {
        videoElement.play();
    }
    // 暂停播放
    function pause() {
        videoElement.pause();
    }
    function PlayOrPause() {
        if(videoElement.paused) {
            videoElement.play();
        }else {
            videoElement.pause();
        }
    }
    function videoEnded(e) {
        videoElement.currentTime = 0;
        this.pause();
    }
    function videoPlay(e) {
        var btnPlay = document.getElementById("btnPlay");
        btnPlay.innerHTML = "暂停";
    }
    function videoPause(e) {
        var btnPlay = document.getElementById("btnPlay");
        btnPlay.innerHTML = "播放";
    }

    实现Fullscreen API

    在HTML5中,新增了一个Fullscreen API,其作用是将页面整体或页面中某个局部区域设为全屏显示状态。

    浏览器支持程度:Firefox10+,chrome16+,Safari5.1+

    在Fullscreen API中,可以通过DOM对象的根节点对象或某个元素的requestFullscreen属性值和执行相对应的方法来判断浏览器是否支持Fullscreen API。代码如下:

    JavaScript

    var docElm = document.documentElement; if(docElm.requestFullscreen) { docElm.requestFullscreen(); }else if(docElm.mozRequestFullScreen) { docElm.mozRequestFullScreen(); }else if(docElm.webkitRequestFullScreen) { docElm.webkitRequestFullScreen(); }

    1
    2
    3
    4
    5
    6
    7
    8
    var docElm = document.documentElement;
    if(docElm.requestFullscreen) {
            docElm.requestFullscreen();
    }else if(docElm.mozRequestFullScreen) {
            docElm.mozRequestFullScreen();
    }else if(docElm.webkitRequestFullScreen) {
            docElm.webkitRequestFullScreen();
    }

    在Fullscreen API中,也可以通过DOM对象或某个元素的exitFullscreen与CanvelFullScreen属性和方法将当前页面或某个元素设定为非全屏显示状态。

    如下代码:

    JavaScript

    if(document.exitFullscreen) { document.exitFullscreen(); }else if(document.mozCancelFullScreen) { document.mozCancelFullScreen(); }else if(document.webkitCancelFullScreen) { document.webkitCancelFullScreen(); }

    1
    2
    3
    4
    5
    6
    7
    if(document.exitFullscreen) {
        document.exitFullscreen();
    }else if(document.mozCancelFullScreen) {
        document.mozCancelFullScreen();
    }else if(document.webkitCancelFullScreen) {
        document.webkitCancelFullScreen();
    }

    在Fullscreen API中,可以通过监听DOM对象或某个元素的fullscreenchange事件(当页面或元素从非全屏显示状态变为全屏显示状态,或从全屏显示状态变为非全屏显示状态时触发)。代码如下:

    JavaScript

    document.addEventListener('fullscreenchange',function(){},false); document.addEventListener('mozfullscreenchange',function(){},false); document.addEventListener('webkitfullscreenchange',function(){},false);

    1
    2
    3
    document.addEventListener('fullscreenchange',function(){},false);
    document.addEventListener('mozfullscreenchange',function(){},false);
    document.addEventListener('webkitfullscreenchange',function(){},false);

    在css样式代码中,我们可以使用伪类选择器来单独指定处于全屏显示状态的页面或元素样式:

    JavaScript

    html:-moz-full-screen { background:red; } html:-webkit-full-screen { background:red; } html:fullscreen { background:red; }

    1
    2
    3
    4
    5
    6
    7
    8
    9
    html:-moz-full-screen {
        background:red;
    }
    html:-webkit-full-screen {
        background:red;
    }
    html:fullscreen {
        background:red;
    }

    最后我们来看一个demo,在页面中有一个按钮,点击后,页面会变成全屏状态,再点击后,页面会退出全屏;

    HTML代码如下:

    JavaScript

    <input type="button" id="btnFullScreen" value="页面全屏显示" onclick="toggleFullScreen();"/> <div style="width:100%;" id="fullscreentState">非全屏显示</div>

    1
    2
    <input type="button" id="btnFullScreen" value="页面全屏显示" onclick="toggleFullScreen();"/>
    <div style="width:100%;" id="fullscreentState">非全屏显示</div>

    Javascript如下:

    JavaScript

    var docElm = document.documentElement; var fullscreentState = document.getElementById("fullscreentState"); var btnFullScreen = document.getElementById("btnFullScreen"); fullscreentState.style.height = docElm.clientHeight + 'px'; document.addEventListener('fullscreenchange',function(){ fullscreentState.innerHTML = (document.fullscreen) ? "全屏显示" : "非全屏显示"; },false); document.addEventListener('mozfullscreenchange',function(){ fullscreentState.innerHTML = (document.mozFullscreen) ? "全屏显示" : "非全屏显示"; },false); document.addEventListener('webkitfullscreenchange',function(){ fullscreentState.innerHTML = (document.webkitFullscreen) ? "全屏显示" : "非全屏显示"; },false); function toggleFullScreen() { if(btnFullScreen.value == '页面全屏显示') { btnFullScreen.value = '页面非全屏显示'; if(docElm.requestFullscreen) { docElm.requestFullscreen(); }else if(docElm.mozRequestFullScreen) { docElm.mozRequestFullScreen(); }else if(docElm.webkitRequestFullScreen) { docElm.webkitRequestFullScreen(); } }else { if(document.exitFullscreen) { document.exitFullscreen(); }else if(document.mozCancelFullScreen) { document.mozCancelFullScreen(); }else if(document.webkitCancelFullScreen) { document.webkitCancelFullScreen(); } btnFullScreen.value = "页面全屏显示"; } }

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    var docElm = document.documentElement;
    var fullscreentState = document.getElementById("fullscreentState");
    var btnFullScreen = document.getElementById("btnFullScreen");
    fullscreentState.style.height = docElm.clientHeight + 'px';
    document.addEventListener('fullscreenchange',function(){
        fullscreentState.innerHTML = (document.fullscreen) ? "全屏显示" : "非全屏显示";
    },false);
    document.addEventListener('mozfullscreenchange',function(){
        fullscreentState.innerHTML = (document.mozFullscreen) ? "全屏显示" : "非全屏显示";
    },false);
    document.addEventListener('webkitfullscreenchange',function(){
        fullscreentState.innerHTML = (document.webkitFullscreen) ? "全屏显示" : "非全屏显示";
    },false);
    function toggleFullScreen() {
        if(btnFullScreen.value == '页面全屏显示') {
            btnFullScreen.value = '页面非全屏显示';
            if(docElm.requestFullscreen) {
                docElm.requestFullscreen();
            }else if(docElm.mozRequestFullScreen) {
                docElm.mozRequestFullScreen();
            }else if(docElm.webkitRequestFullScreen) {
                docElm.webkitRequestFullScreen();
            }
        }else {
            if(document.exitFullscreen) {
                document.exitFullscreen();
            }else if(document.mozCancelFullScreen) {
                document.mozCancelFullScreen();
            }else if(document.webkitCancelFullScreen) {
                document.webkitCancelFullScreen();
            }
            btnFullScreen.value = "页面全屏显示";
        }
    }

    赞 收藏 评论

    彩世界平台 1

    译文来源:

    原文:HTML5 Page Visibility API

    译文:HTML 5的页面可视性API

    译者:dwqs

     彩世界平台 2

    在早期,浏览器并没有提供选项卡,但是现在基本所有浏览器都提供了这个功能。作为一个程序员,我一般会同时打开10到15个选项卡,甚至有些时候会在25到30.

    为什么介绍Page Visibility API呢?

    之前,是不可能确定哪个选项卡是激活的,哪个没有激活,但是在HTML 5 Visibility API的帮助下,就可以检测用户是否在浏览某个网站的页面。

    在这篇文章中,我们将会理解如何使用HTML 5 Visibility API,并且用一个小demo去发觉页面的状态。在这个demo中,将基于页面的可视性状态弹出文档的标题。

    检查页面的可见性

    为了使用Visibility API,我们要先了解两个新的文档属性,第一个是document.visibilityState,另一个是document.hidden.它们的功能是不同的。

    document.visibilityState有四个不同的值:

    1、hidden:页面在任何屏幕上不可见

    2、prerender:页面在加载,对用户不可见

    3、visible:页面可见

    4、unloaded:页面卸载(即用户将离开当前页面)

    document.hidden是一个布尔值,false表示页面可见,true表示页面不可见。

    既然知道了可用的属性,就是时候去监听事件了,这样子就可以知道页面的可见性是什么状态。这是

    利用visibilitychange事件完成的,示例如下:

    document.addEventListener('visibilitychange', function(event) {
      if (!document.hidden) {
        // The page is visible.
      } else {
       // The page is hidden.
      }
    });
    

     

              这段代码是visibilitychange事件的一个简单应用—检测当前页面的状态。但是你必须知道的是所有属性和方法都必须带前缀,因为他们在一些浏览器中是带私有前缀的。下面则是一个跨浏览器的案例:

    // Get Browser-Specifc Prefix
    function getBrowserPrefix() {
    
      // Check for the unprefixed property.
      if ('hidden' in document) {
        return null;
      }
    
      // All the possible prefixes.
      var browserPrefixes = ['moz', 'ms', 'o', 'webkit'];
    
      for (var i = 0; i < browserPrefixes.length; i++) {
        var prefix = browserPrefixes[i] + 'Hidden';
        if (prefix in document) {
          return browserPrefixes[i];
        }
      }
    
      // The API is not supported in browser.
      return null;
    }
    
    // Get Browser Specific Hidden Property
    function hiddenProperty(prefix) {
      if (prefix) {
        return prefix + 'Hidden';
      } else {
        return 'hidden';
      }
    }
    
    // Get Browser Specific Visibility State
    function visibilityState(prefix) {
      if (prefix) {
        return prefix + 'VisibilityState';
      } else {
        return 'visibilityState';
      }
    }
    
    // Get Browser Specific Event
    function visibilityEvent(prefix) {
      if (prefix) {
        return prefix + 'visibilitychange';
      } else {
        return 'visibilitychange';
      }
    }
    

     

            现在有了所有浏览器带前缀的属性和方法,就可以放心应用了。对之前的代码做出调整:

    // Get Browser Prefix
    var prefix = getBrowserPrefix();
    var hidden = hiddenProperty(prefix);
    var visibilityState = visibilityState(prefix);
    var visibilityEvent = visibilityEvent(prefix);
    
    document.addEventListener(visibilityEvent, function(event) {
      if (!document[hidden]) {
        // The page is visible.
      } else {
       // The page is hidden.
      }
    });
    

    本文由彩世界平台发布于新闻动态,转载请注明出处:彩世界平台杂谈:HTML 5页面可视性API

    关键词:

上一篇:Chrome开发者工具不完全指南

下一篇:没有了