谷歌浏览器调用webkitRequestFullScreen方法后,设置的背景色只填充可视范围问题。

1、问题根因

 谷歌浏览器对全屏模式下默认的样式

背景色是白色,而body一般是不设置高度或者设置高度为100%,背景色只对可视范围生效。

2、解决思路

    设置全屏状态下的样式,和body的样式一致,覆盖掉默认的颜色。

//各个浏览器下 全屏状态下背景色设置  
:-webkit-full-screen {  
  background-color: @content-bg !important;  
}  
:-moz-full-screen {  
  background-color: @content-bg !important;  
}  
  
:-ms-fullscreen {  
  background-color: @content-bg !important;  
}  
:fullscreen {  
  background-color: @content-bg !important;  
}  
3、参考文章

1)css相关

CSS :fullscreen伪类选择器用于匹配当前全屏显示的元素。

大多数的现代浏览器都可以进入全屏模式。你可以尝试按下F11键,测试一下浏览器进入全屏模式的样子。

但是,如果你的页面中有某个元素,你想选择它,并使用:fullscreen伪类选择器使它进入全屏模式,你会发现这是不可行的。要使一个元素被:fullscreen伪类匹配,并进入全屏模式,你只有使用HTML5 Fullscreen API才能办到。

关于HTML5 Fullscreen API,它的简单使用方法类似下面的样子:

var el = document.getElementByID( 'element' );
 
// use necessary prefixed versions
el.webkitRequestFullscreen();
el.mozRequestFullScreen();
el.msRequestFullscreen();
 
// finally the standard version
el.requestFullscreen();

上面的代码中的el元素现在可以被:fullscreen伪类匹配,你可以为它设置需要的样式:

#element:fullscreen {
     width : 100 vw;
     height : 100 vh;
     ......
}
 示例代码

下面的示例代码为某个元素进入全屏模式的元素设置样式,使它填充满整个视口。

.el:-webkit-full- screen {
   width : 100 vw;
   height : 100 vh;
}
 
.el:-moz-full- screen {
   width : 100 vw;
   height : 100 vh;
}
 
.el:-ms-fullscreen {
   width : 100 vw;
   height : 100 vh;
}
 
.el:fullscreen {
   width : 100 vw;
   height : 100 vh;
}

下面的示例代码在图片进入全屏模式时,隐藏它的描述信息。

figure:-webkit-full- screen figcaption {
   display : none ;
}
 
figure:-moz-full- screen figcaption {
   display : none ;
}
 
figure:-ms-fullscreen figcaption {
   display : none ;
}
 
figure:fullscreen figcaption {
   display : none ;
}

下面的代码在进入全屏模式时,隐藏所有class为foo的元素。

:-webkit-full- screen .foo {
   display : none ;
}
 
:-moz-full- screen .foo {
   display : none ;
}
 
:-ms-fullscreen .foo {
   display : none ;
}
 
:fullscreen .foo {
   display : none ;
}
 浏览器支持

:fullscreen伪类选择器被以下浏览器支持:

  • Chrome(需要添加-webkit-前缀:-webkit-full-screen
  • Firefox(需要添加-moz-前缀:-moz-full-screen
  • nternet Explorer 11+(需要添加-ms-前缀:-ms-full-screen

支持Fullscreen API的浏览器参考下面的浏览器兼容性列表:

谷歌浏览器调用webkitRequestFullScreen方法后,设置的背景色只填充可视范围问题。_第1张图片

2)API相关

HTML5全屏API在FireFox/Chrome中的显示差异谷歌浏览器调用webkitRequestFullScreen方法后,设置的背景色只填充可视范围问题。_第2张图片

这篇文章发布于 2012年10月8日,星期一,21:30,归类于 web综合。 阅读 89842 次, 今日 10 次

一、人人网上……

今天,在人人网上看同学晒得照片的时候,发现了这个按钮:

这个按钮是?我移了好几遍,没有title提示。图形也不具有代表性,一个圈圈意思是?——圈人??是不是啊??不敢点,点了不知道会发生什么,浏览器会不会关掉!!我思想斗争做了很久,终于弱弱地点了一下~~

草骆驼,居然是——全屏显示的提示:

人人兄,使用新技术固然值得提倡,这个圈圈也不加个提示——让人知道点了之后是全屏啊!!否则,俺们脆弱的小心脏根本承受不起啊——屏幕立马黑了个通透——还以为盖茨发现我的系统是盗版的黑了我的屏呢!!!

好吧,玩完两把三国杀,情绪稳定了,回到正题。人人网这个全屏效果就是使用的HTML5的全屏API,使用其实很easy的!对于全屏API,年初的时候就有耳闻,但未做测试与了解,现在,人人君已经用在实际项目中了,显然,有必要了解一番,可以在自己的项目中耍耍酷,过过HTML5的瘾。

二、相关文章以及一些技术点

搜了下,介绍的文章还不少,您可以参考:

  • 武方博原创的html5实现全屏的api方法一文。文章前面属于备忘性质的内容,没看头;不过,最后的心得很不错,实际应用经验,值得一看。
  • heero翻译的“[译]原生全屏Javascript API”。去年时候内容,稍微old的点,多理论,有值得注意的知识点,能了解API的大概。
  • sitePoint上的”How to Use the HTML5 Full-Screen API“, 较新的文章吗,跟实际应用走的也很近,有demo,更值得参考。

如果您正好处于节后综合症发病期,懒得点击上面链接,也可以看下面我精简出来的一些实用的东西:

  1. 全屏效果JavaScript实现
  2. 全屏效果clickmousedwonmouseup事件才能触发
  3. 全屏方法为:全屏元素.requestFullScreen(); 目前不同的浏览器需要不同的前缀,如mozRequestFullScreenwebkitRequestFullScreen
  4. 取消全屏为:全屏元素.cancelFullScreen(); 同样,不同浏览器需要添加私有前缀,如mozCancelFullScreenwebkitCancelFullScreen.
  5. 可以通过document.fullScreen判断浏览器是否处于全屏状态。注意:FireFox和Chrome写法上有不同,Webkit内核浏览器需要增加个is, 如document.webkitIsFullScreen; 而Firefox则是document.mozFullScreen.
  6. :full-screen{}用在CSS代码中,可以控制全屏元素(及其子元素)全屏状态时的样式。同样,不同浏览器不同前缀。如:-moz-full-screen{}:- webkit-full-screen{}.
  7. 一个页面如果有多个全屏元素,在CSS控制的时候,可以使用类似#element:full-screen{}的选择器分别控制。

如果以上密密麻麻的文字看得你头大眼花,换个轻松的浏览,您可以狠狠地点击这里:HTML5 full-screen全屏API测试demo

点击demo页面中的美女照片,即可触发全屏浏览提示。

该demo几乎均遵循了上面概要的一些技术tips, 完整代码demo页面上均有,不难懂的,大家有兴趣可以看看。

如果您想在实际项目中使用HTML5全屏API,demo页面中出现的这个方法必不可少(可以兼容以后N多年的HTML5发展):

var runPrefixMethod = function(element, method) {
    var usablePrefixMethod;
    ["webkit", "moz", "ms", "o", ""].forEach(function(prefix) {
        if (usablePrefixMethod) return;
        if (prefix === "") {
            // 无前缀,方法首字母小写
            method = method.slice(0,1).toLowerCase() + method.slice(1);
            
        }
        
        var typePrefixMethod = typeof element[prefix + method];
        
        if (typePrefixMethod + "" !== "undefined") {
            if (typePrefixMethod === "function") {
                usablePrefixMethod = element[prefix + method]();
            } else {
                usablePrefixMethod = element[prefix + method];
            }
        }
    });
    
    return usablePrefixMethod;
};

既是方法执行(如果是方法),又是属性判断(是否支持属性),很实用,可以直接拷贝粘贴使用。

OK,这里所说的东西,其实上面几篇参考文章都有说过,没意思!现在目光转移到下面,呼吸一些新鲜的空气~~

三、FireFox/Chrome中的显示差异

表象的差异:
表象的差异就是是否支持全屏提示的差异了,FireFox浏览器以前是个大框框,现在UI和则简约的多:

而Chrome浏览器下是个实色背景(参见下截图):

浏览器生产商的喜好,没什么好说的。

更细致的差异:
如果您观察够仔细,您可能会发现,在全屏状态下,FireFox浏览器下点击界面的任意位置,都会回到正常状态;但是Chrome浏览器下,只有点击图片才能回到正常状态。下面两张图是同一位置,鼠标手形的差异对比:
 

深层次的原因:
虽然,demo页面中,背景都是全屏的黑色,图片效果一样,高度60%放大显示,垂直且水平居中,但是,其背后实现的机制却是很不一样的。

FireFox浏览器对全屏元素进行的一些CSS属性的强设置,打开FireBug,查看系统默认样式,您会看到:

也就是,元素宽高100%显示,黑色背景,固定定位——这也是为什么FireFox浏览器下点击屏幕任意位置会退出全屏——因为绑定了事件的全屏元素满屏显示了。

背景色非强设置,通过如下CSS,我们就可以进行修改:

:-moz-full-screen {
    background-color: #fff;
}

结果,就是下图这个样子,黑色背景变成白色背景了:

而Chrome浏览器下,虽然默认对全屏元素也有CSS设置,但是寥寥:

好吧,基本上就是两个酱油CSS设置,背景色还是白色的。

现在问题来了?为何两个浏览器默认的全屏CSS样式不一样,但是,都是黑色背景,图片垂直水平居中呢!!!

解释:FireFox浏览器下的黑色背景就是全屏元素,其中图片的居中对齐是通过CSS控制的(:after伪类生成元素+vertical-align:middle实现),例如去掉text-align:center图片就不水平居中了;而Chrome的黑色背景属于系统的东西,其全屏元素似乎被浏览器劫持,默认状况下永远屏幕居中显示(去掉text-align:center图片依然水平居中)——脱离了常规CSS理解——如默认的display:block状态似乎变成了display:inline-block等。

然而,我们是有办法让Chrome表现得跟FireFox浏览器一样地,就是增加一样FireFox浏览器默认有的样式,如:

:-webkit-full-screen {
    background-color: black;
    position: fixed;
    top: 0;
    right: 0;
    left: 0;
    bottom: 0;	
}

于是,这样子,即使在Chrome浏览器下,点击屏幕的任意位置,全屏状态都会退出!

你可能感兴趣的:(js基础,兼容性,ng-alain,CSS)