We may see a lot of exiting full-screen effects and full-screen effects when watching video websites. Here we will introduce you to the use of js full-screen and exit full-screen code examples. Friends who need it can refer to it
JS full screen and exit full screen
js implements the functions of browser window full screen and exit full screen. Mainstream browsers on the market such as: Google, Firefox, 360, etc. are all compatible, but the lower version of IE is a bit Flaws (there is still a status bar at the bottom in full screen mode).
This demo is basically enough. Just copy the source code below and save it as an html file to see the effect.
<!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}"); } } }
//Exit full screen to determine browser type
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>
We know, browse To go full screen, usually press the shortcut key F11. It is not uncommon for JS to control the browser's full screen. It makes web applications look more like native software applications. For example, ordering system, calling system, etc.
There are many JS methods to make the browser full screen and exit full screen. This is not the point. The point is to note: browser full screen can only be triggered by mouse gesture click events.
JS full screen method
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 exit full screen method
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); }
Console warning
Failed to execute 'requestFullscreen' on 'Element': API can only be initiated by a user gesture.
Interpretation: on "Element" Execution of the "requestFullscreen" method failed, the javascript API only allows creation through gestures! (i.e. no permission)
Usually caused by the programmer wanting to trigger the browser to automatically display full screen. But I'm sorry, this method doesn't work. It must be created through gestures. Even onload, trigger(), and mouseover cannot be triggered!
Official explanation
The Element.requestFullscreen() method issues an asynchronous request to display the element in full screen. But there is no guarantee that the element will be put into full screen mode.
If full screen mode is allowed, the document will receive a fullscreenchange event to let it know that it is now in full screen mode. If permission is denied, the document receives a FullScreenError event.
Conclusion
Maybe for the sake of user experience, client-side javascript allows the browser to be full-screen only through mouse gesture click events, that is, click() .
The above is what I compiled for everyone. I hope it will be helpful to everyone in the future.
Related articles:
Nodejs Electron ubuntu installation steps detailed explanation
Native JS AJAX Produce three-level linkage effect (with code)
Vue.jsTwo-way binding implementation step instructions
The above is the detailed content of Detailed explanation of JS full screen and exit full screen (including code). For more information, please follow other related articles on the PHP Chinese website!