在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。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值