当前位置: 移动技术网 > IT编程>开发语言>JavaScript > JS 全屏和退出全屏详解及实例代码

JS 全屏和退出全屏详解及实例代码

2019年07月19日  | 移动技术网IT编程  | 我要评论

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()。

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网