、需求分析
1、需求:点击关闭之后,顶部广告图可以关闭
2、分析:
点击的是关闭按钮
关闭的是父盒子
利用样式的显示和隐藏完成, display:none 隐藏元素 display:block 显示元素
<script src="https://lf3-cdn-tos.bytescm.com/obj/cdn-static-resource/tt_player/tt.player.js?v=20160723"></script>
二、HTML代码准备
准备好一个div盒子,在里面放上图片和一个小的div盒子
HTML代码准备
三、CSS样式设置
1、导入css外部样式文件
导入css外部样式文件
2、给大的div盒子设置宽高1190px*80px
div大盒子样式设置
3、小的div盒子设置宽高20px*20px,背景色为#666,文字X水平居中、行高20px(行高为了垂直居中),鼠标移到上面的时候变为小手(cursor: pointer)
div小盒子样式设置
4、定位小盒子到广告图右上角,利用父相对,子绝对的定位方法,将小盒子移动到距离图片顶部和右侧5px的位置
定位小盒子到广告图右上角
CSS样式设置好后效果图
四、点击关闭功能实现
1、导入js外部文件
导入js外部文件
2、获取元素对象,分别获取大盒子和小盒子的元素对象
获取元素对象
3、点击小盒子时,关闭大盒子(将大盒子隐藏,即将大盒子的display属性值改为none)
点击小盒子时,关闭大盒子
以上就是如何实现京东点击关闭顶部广告功能的方法,你学“废”了吗
我
ello,大家好,今天讲一个js的广告图片下落的js的demo
上效果图,当你打开一个网页时会有广告下落,那么我们怎么写js呢?效果图:
先写html代码:
再写javascript代码:
好了,今天的js分享结束了,记得关注暖夕H2
#头条创作挑战赛#
本文同步本人掘金平台的文章:https://juejin.cn/post/7135830434528624654
今天,我们来探讨的问题是:
当点击图片的时候,我们需要其全屏展示,当我们再次点击的时候,图片退出全屏播放。
PS: 我们退出全屏播放的情况一般是按 esc 退出。图片可以延伸到任何的 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 进行按钮事件(调用退出全屏的函数)
复制代码
你学废了?
如果读者觉得文章还可以,不防一键三连:关注➕点赞➕收藏
*请认真填写需求信息,我们会在24小时内与您取得联系。