JS 全屏和退出全屏详解及实例代码
JS全屏和退出全屏
js实现浏览器窗口全屏和退出全屏的功能,市面上主流浏览器如:谷歌、火狐、360等都是兼容的,不过IE低版本有点瑕疵(全屏状态下仍有底部的状态栏)。
这个demo基本是够了,直接复制下面的源码另存为html文件看效果吧。
<!DOCTYPEhtml>
<html>
<metahttp-equiv="Content-Type"content="text/html;charset=utf-8"/>
<title>js全屏和退出全屏代码</title>
<body>
<!--requestFullScreen(document.documentElement):整个网页进入全屏
requestFullScreen(document.getElementById("video-box")):指定某块区域全屏
-->
<buttononclick="requestFullScreen(document.documentElement)">全屏显示</button>
<buttononclick="exitFull()">退出全屏</button>
</body>
<scripttype="text/javascript">
functionrequestFullScreen(element){
//判断各种浏览器,找到正确的方法
varrequestMethod=element.requestFullScreen||//W3C
element.webkitRequestFullScreen||//Chrome等
element.mozRequestFullScreen||//FireFox
element.msRequestFullScreen;//IE11
if(requestMethod){
requestMethod.call(element);
}
elseif(typeofwindow.ActiveXObject!=="undefined"){//forInternetExplorer
varwscript=newActiveXObject("WScript.Shell");
if(wscript!==null){
wscript.SendKeys("{F11}");
}
}
}
//退出全屏判断浏览器种类
functionexitFull(){
//判断各种浏览器,找到正确的方法
varexitMethod=document.exitFullscreen||//W3C
document.mozCancelFullScreen||//Chrome等
document.webkitExitFullscreen||//FireFox
document.webkitExitFullscreen;//IE11
if(exitMethod){
exitMethod.call(document);
}
elseif(typeofwindow.ActiveXObject!=="undefined"){//forInternetExplorer
varwscript=newActiveXObject("WScript.Shell");
if(wscript!==null){
wscript.SendKeys("{F11}");
}
}
}
</script>
</html>
感谢阅读,希望嫩帮助到大家,谢谢大家对本站的支持!
以下是其它网友的补充
我们知道,浏览器全屏通常按快捷键F11。JS控制浏览器全屏也不稀奇,它让Web应用看上去更像似原生软件应用效果。比如点餐系统、叫号系统等等。
JS让浏览器全屏及退出全屏的方法网上很多,这不是重点,重点是需注意:浏览器全屏只能通过鼠标手势点击事件去触发。
JS全屏方法
var$fullScreen=document.getElementById("js-fullScreen");//按钮
if($fullScreen){
$fullScreen.addEventListener("click",function(){
vardocElm=document.documentElement;
if(docElm.requestFullscreen){
docElm.requestFullscreen();
}
elseif(docElm.msRequestFullscreen){
docElm.msRequestFullscreen();
}
elseif(docElm.mozRequestFullScreen){
docElm.mozRequestFullScreen();
}
elseif(docElm.webkitRequestFullScreen){
docElm.webkitRequestFullScreen();
}
},false);
}
JS退出全屏方法
var$cancelFullScreen=document.getElementById("js-cancelFullScreen");
if($cancelFullScreen){
$cancelFullScreen.addEventListener("click",function(){
if(document.exitFullscreen){
document.exitFullscreen();
}
elseif(document.msExitFullscreen){
document.msExitFullscreen();
}
elseif(document.mozCancelFullScreen){
document.mozCancelFullScreen();
}
elseif(document.webkitCancelFullScreen){
document.webkitCancelFullScreen();
}
},false);
}
控制台警告
Failedtoexecute'requestFullscreen'on'Element':APIcanonlybeinitiatedbyausergesture.
释义:在"Element"上执行"requestFullscreen"方法失败,javascriptAPI仅允许通过手势去创建!(即没有权限)
通常是由于程序员想触发浏览器自动全屏显示而导致。但是很抱歉,此方法行不通,必须通过手势去创建,哪怕onload、trigger()、mouseover也触发不了!
官方解释
该Element.requestFullscreen()方法发出异步请求,使元素全屏显示。但不能保证元素将被放入全屏模式。
如果允许进入全屏模式,文档将收到一个fullscreenchange事件,让它知道它现在处于全屏模式。如果权限被拒绝,则文档会接收到一个fullscreenerror事件。
结论
可能出于用户操作体验的考虑吧,客户端javascript让浏览器全屏只能通过鼠标手势点击事件去触发,即click()。