网站首页 > 知识剖析 正文
本文同步本人掘金平台的文章:
https://juejin.cn/post/7135830434528624654
今天,我们来探讨的问题是:
当点击图片的时候,我们需要其全屏展示,当我们再次点击的时候,图片退出全屏播放。
PS: 我们退出全屏播放的情况一般是按 esc 退出。图片可以延伸到任何的 DOM 节点
在文末,我会将问题升级,留一个题目给读者思考
图片全屏,这个跟文章全屏的效果一样,比如下面的文章全屏:
就是一个元素铺平整个屏幕
思路
那么,问题我们知道了。解决问题的思路是怎么样的呢?
- 我们获取到图片元素的 DOM 节点
- 我们调用全屏的函数进行全屏展示
- 浏览器监听点击事件,当图片是全屏的状态,再次点击图片的时候,调用函数退出全屏
好了,思路有了,我们来实现下。
具体实现
假设我们有 html 代码如下:
<img id="image" src="path/to/image.postfix" alt="img" />
复制代码
现在我们编写下 javascript 代码。
// 退出全屏
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 来编写
当然,上面的代码并没有考虑相关的兼容性。
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)。
问题升级
单点击图片,我们需要其全屏展示。然后设置全屏时候,右上角有一个退出的按钮。点击退出按钮,退出全屏展示。
感兴趣的读者可以先自己尝试下。
这里我给出简单的思路,可以作为参考。
答案(点击展开)
1. 设定布局,将一个 div 包裹图片
2. 在 div 中设置一个按钮的元素 button,并对 button 进行 css 布局
3. 在图片全屏的时候,显示 button,并对 button 进行按钮事件(调用退出全屏的函数)
复制代码
你学废了?
如果读者觉得文章还可以,不防一键三连:关注点赞收藏
猜你喜欢
- 2025-09-09 JavaScript:history和location对象、JS设计模式系统讲解与应用
- 2025-09-09 3种方式让WebAssembly与JavaScript飞起来!性能提升300%的实战
- 2025-09-09 JavaScript 的图片背景色提取开源库,能让图片和背景融为一体
- 2025-09-09 让网站动起来的js库,真漂亮,再也不用写复杂的动画了~wow.js
- 2025-09-09 前端惊魂夜:我竟在CSS里写出了JavaScript?
- 最近发表
-
- 用Python把表格做成web可视化图表
- 太秀了!Excel批量生成条形码和二维码,一个公式就能解决
- 制作Excel电子表格必备的:Excel 2021 mac中文版
- C#/VB.NET:将 HTML 转换为 Excel_如何将html中的数据转换到excel中
- 如何快速写出表格代码?exl表格转换成html代码
- 一看就懂的Excel表格的基本操作的十大技巧
- Java发送包含表格的邮件_java发邮件内容含表格
- Python——Html(表格, , ,、表单 、自定义标签 和)
- 太漂亮了 ! 输出好看的表格,就用这个 Python 库
- AI实用指南:对抗AI幻觉的秘诀与Cursor+Claude 3.7编程Rules技巧
- 标签列表
-
- xml (46)
- css animation (57)
- array_slice (60)
- htmlspecialchars (54)
- position: absolute (54)
- datediff函数 (47)
- array_pop (49)
- jsmap (52)
- toggleclass (43)
- console.time (63)
- .sql (41)
- ahref (40)
- js json.parse (59)
- html复选框 (60)
- css 透明 (44)
- css 颜色 (47)
- php replace (41)
- css nth-child (48)
- min-height (40)
- xml schema (44)
- css 最后一个元素 (46)
- location.origin (44)
- table border (49)
- html tr (40)
- video controls (49)