您好,欢迎访问一九零五行业门户网

JS 全屏和退出全屏详解(含有代码)

退出全屏效果与全屏效果我们可能在看视频网站时看到多,这里来为各位介绍利用js全屏和退出全屏代码范例吧,,需要的朋友可以参考下
js 全屏和退出全屏
js实现浏览器窗口全屏和退出全屏的功能,市面上主流浏览器如:谷歌、火狐、360等都是兼容的,不过ie低版本有点瑕疵(全屏状态下仍有底部的状态栏)。
这个demo基本是够了,直接复制下面的源码另存为html文件看效果吧。
<!doctype html> <html> <meta http-equiv="content-type" content="text/html; charset=utf-8" /> <title>js全屏和退出全屏代码</title> <body> <!-- requestfullscreen(document.documentelement): 整个网页进入全屏 requestfullscreen(document.getelementbyid("video-box")): 指定某块区域全屏 --> <button onclick="requestfullscreen(document.documentelement)">全屏显示</button> <button onclick="exitfull()">退出全屏</button> </body> <script type="text/javascript"> function requestfullscreen(element) { // 判断各种浏览器,找到正确的方法 var requestmethod = element.requestfullscreen || //w3c element.webkitrequestfullscreen || //chrome等 element.mozrequestfullscreen || //firefox element.msrequestfullscreen; //ie11 if (requestmethod) { requestmethod.call(element); } else if (typeof window.activexobject !== "undefined") {//for internet explorer var wscript = new activexobject("wscript.shell"); if (wscript !== null) { wscript.sendkeys("{f11}"); } } }
//退出全屏 判断浏览器种类
function exitfull() { // 判断各种浏览器,找到正确的方法 var exitmethod = document.exitfullscreen || //w3c document.mozcancelfullscreen || //chrome等 document.webkitexitfullscreen || //firefox document.webkitexitfullscreen; //ie11 if (exitmethod) { exitmethod.call(document); } else if (typeof window.activexobject !== "undefined") {//for internet explorer var wscript = new activexobject("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 () { var docelm = document.documentelement; if (docelm.requestfullscreen) { docelm.requestfullscreen(); } else if (docelm.msrequestfullscreen) { docelm.msrequestfullscreen(); } else if (docelm.mozrequestfullscreen) { docelm.mozrequestfullscreen(); } else if (docelm.webkitrequestfullscreen) { docelm.webkitrequestfullscreen(); } }, false); }
js退出全屏方法
var $cancelfullscreen = document.getelementbyid("js-cancelfullscreen"); if ($cancelfullscreen) { $cancelfullscreen.addeventlistener("click", function () { if (document.exitfullscreen) { document.exitfullscreen(); } else if (document.msexitfullscreen) { document.msexitfullscreen(); } else if (document.mozcancelfullscreen) { document.mozcancelfullscreen(); } else if (document.webkitcancelfullscreen) { document.webkitcancelfullscreen(); } }, false); }
控制台警告
failed to execute 'requestfullscreen' on 'element': api can only be initiated by a user gesture.
释义:在element上执行requestfullscreen方法失败,javascript api仅允许通过手势去创建!(即没有权限)
通常是由于程序员想触发浏览器自动全屏显示而导致。但是很抱歉,此方法行不通,必须通过手势去创建,哪怕onload、trigger()、mouseover也触发不了!
官方解释
该element.requestfullscreen()方法发出异步请求,使元素全屏显示。但不能保证元素将被放入全屏模式。
如果允许进入全屏模式,文档将收到一个fullscreenchange事件,让它知道它现在处于全屏模式。如果权限被拒绝,则文档会接收到一个fullscreenerror事件。
结论
可能出于用户操作体验的考虑吧,客户端javascript让浏览器全屏只能通过鼠标手势点击事件去触发,即click()。
上面是我整理给大家的,希望今后会对大家有帮助。
相关文章:
nodejs+electron ubuntu安装步骤详解
原生js+ajax做出三级联动效果(附代码)
vue.js双向绑定实现步骤说明
以上就是js 全屏和退出全屏详解(含有代码)的详细内容。
其它类似信息

推荐信息