在js中如何去实现全屏事件?

简介: 在js中如何去实现全屏事件?

在实际开发中,我们很可能需要实现某一元素的全屏和退出全屏功能,如canvas。所幸的是,js提供了相关api用来处理这一问题,只需简单的调用requestFullScreen 、exitFullScreen即可。但这两个api一般而言需要考虑其兼容性问题,那么就需要额外封装一下。

一:进入全屏

//全屏的兼容
const fullscreen = ele => {
const func =
ele.requestFullscreen ||
ele.mozRequestFullscreen ||
ele.webkitRequestFullscreen ||
ele.msRequestFullscreen;
func.call(ele);
};

在上面的函数中,首先是判断浏览器支持的api是哪一个,以实现兼容,而后调用它。在调用的时候需要重新绑定一下ele,否则会报错。这种写法避免了繁琐的if else 写法,更加易读。

二:退出全屏

//退出全屏的兼容
const exitFullscreen = () => {
const func =
document.exitFullScreen ||
document.mozcancelFullscreen ||
document.webkitExitFullscreen ||
document.msExitFullscreen;
func.call( document);
};

理由同上,这里需要注意的是,无需再传递dom元素,因为退出全屏属于document 的api。

相关文章
|
3月前
|
Web App开发 JavaScript 前端开发
javascript onkeydown事件
javascript onkeydown事件
|
3月前
|
JavaScript
js两种移除事件的方法
js两种移除事件的方法
45 3
|
2月前
|
缓存 JavaScript 前端开发
JavaScript 与 DOM 交互的基础及进阶技巧,涵盖 DOM 获取、修改、创建、删除元素的方法,事件处理,性能优化及与其他前端技术的结合,助你构建动态交互的网页应用
本文深入讲解了 JavaScript 与 DOM 交互的基础及进阶技巧,涵盖 DOM 获取、修改、创建、删除元素的方法,事件处理,性能优化及与其他前端技术的结合,助你构建动态交互的网页应用。
55 5
|
3月前
|
存储 JavaScript 前端开发
js事件队列
【10月更文挑战第15天】
58 6
|
4月前
|
JavaScript 前端开发
JavaScript HTML DOM 事件
JavaScript HTML DOM 事件
29 5
|
3月前
|
JavaScript API
深入解析JS中的visibilitychange事件:监听浏览器标签间切换的利器
深入解析JS中的visibilitychange事件:监听浏览器标签间切换的利器
179 0
|
3月前
|
JavaScript
js两种移除事件的方法
js两种移除事件的方法
63 0
|
3月前
|
JavaScript 前端开发 API
JavaScript全屏,监听页面是否全屏
JavaScript全屏,监听页面是否全屏
70 0
|
3月前
|
JavaScript
js两种移除事件的方法
js两种移除事件的方法
|
3月前
|
JavaScript 前端开发 Android开发
JavaScript触摸touch事件
JavaScript触摸touch事件