JavaScript 实现点击/关闭全屏

JavaScript 实现点击/关闭全屏今天 我们来探讨的问题是 当点击图片的时候 我们需要其全屏展示 当我们再次点击的时候 图片退出全屏播放

欢迎大家来到IT世界,在知识的湖畔探索吧!

#头条创作挑战赛#

JavaScript 实现点击/关闭全屏



欢迎大家来到IT世界,在知识的湖畔探索吧!

本文同步本人掘金平台的文章:
https://juejin.cn/post/

今天,我们来探讨的问题是:

当点击图片的时候,我们需要其全屏展示,当我们再次点击的时候,图片退出全屏播放。

PS: 我们退出全屏播放的情况一般是按 esc 退出。图片可以延伸到任何的 DOM 节点

在文末,我会将问题升级,留一个题目给读者思考

图片全屏,这个跟文章全屏的效果一样,比如下面的文章全屏:

JavaScript 实现点击/关闭全屏

就是一个元素铺平整个屏幕

思路

那么,问题我们知道了。解决问题的思路是怎么样的呢?

  1. 我们获取到图片元素的 DOM 节点
  2. 我们调用全屏的函数进行全屏展示
  3. 浏览器监听点击事件,当图片是全屏的状态,再次点击图片的时候,调用函数退出全屏

好了,思路有了,我们来实现下。

具体实现

假设我们有 html 代码如下:

<img id="image" src="path/to/image.postfix" alt="img" /> 复制代码

欢迎大家来到IT世界,在知识的湖畔探索吧!

现在我们编写下 javascript 代码。

欢迎大家来到IT世界,在知识的湖畔探索吧!// 退出全屏 ngAfterViewInit() { const image = document.getElementById('image'); image.addEventListener('click', (event: any) => { if(document.fullscreenElement === image) { document.exitFullscreen(); } event.preventDefault(); }) } // 全屏查看 public fullscreenView(): void { const image = document.getElementById('image'); image.requestFullscreen() } 复制代码

这里我用了 typescript 来编写

当然,上面的代码并没有考虑相关的兼容性。

JavaScript 实现点击/关闭全屏

JavaScript 实现点击/关闭全屏

requestFullscreen 和 exitFullscreen 方法对现代的浏览器支持还是很可以的,在 PC 端上展示毫无压力。

但是,我们还是得对代码进行浏览器兼容写法:

这里我新建了个 utils.ts 的文件:

export class Utils { public static gotoFullscreen(dom: any): void { if (dom.requestFullscreen) { dom.requestFullscreen() } else if (dom.mozRequestFullScreen) { dom.mozRequestFullScreen() } else if (dom.webkitRequestFullscreen) { dom.webkitRequestFullscreen() } else if (dom.msRequestFullscreen) { dom.msRequestFullscreen() } else { console.error('当前浏览器不支持部分全屏!') } } public static exitFullscreen(dom: any): void { if (dom.exitFullscreen) { dom.exitFullscreen() } else if (dom.webkitExitFullscreen) { dom.webkitExitFullscreen() } else if (dom.msExitFullscreen) { dom.msExitFullscreen() } } } 复制代码

上面两个方法都是静态方法,调用方式 类名.静态方法,比如:Utils.gotoFullscreen(dom)。

问题升级

单点击图片,我们需要其全屏展示。然后设置全屏时候,右上角有一个退出的按钮。点击退出按钮,退出全屏展示。

感兴趣的读者可以先自己尝试下。

这里我给出简单的思路,可以作为参考。

答案(点击展开)

欢迎大家来到IT世界,在知识的湖畔探索吧!1. 设定布局,将一个 div 包裹图片 2. 在 div 中设置一个按钮的元素 button,并对 button 进行 css 布局 3. 在图片全屏的时候,显示 button,并对 button 进行按钮事件(调用退出全屏的函数) 复制代码

你学废了?

JavaScript 实现点击/关闭全屏

如果读者觉得文章还可以,不防一键三连:关注➕点赞➕收藏

免责声明:本站所有文章内容,图片,视频等均是来源于用户投稿和互联网及文摘转载整编而成,不代表本站观点,不承担相关法律责任。其著作权各归其原作者或其出版社所有。如发现本站有涉嫌抄袭侵权/违法违规的内容,侵犯到您的权益,请在线联系站长,一经查实,本站将立刻删除。 本文来自网络,若有侵权,请联系删除,如若转载,请注明出处:https://itzsg.com/128653.html

(0)
上一篇 1小时前
下一篇 1小时前

相关推荐

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们YX

mu99908888

在线咨询: 微信交谈

邮件:itzsgw@126.com

工作时间:时刻准备着!

关注微信