1、原生方法
js的contains方法用来查看dom元素的包含关系
<div id="box" style="width:110px;height:110px;background-color:red"></div>
<script type="text/javascript">
document.addEventListener('click', (e)=> {
var box = document.getElementById('box');
if (box.contains(e.target)) {
alert('点在内');
} else {
alert('点在外');
}
})
</script>
2、 vue 写法
ref是vue获取DOM元素的方法,在标签上绑定ref属性,js在组件内部用this.$refs.ref的值,调用。
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>BFW NEW PAGE</title>
<script id="bfwone" data="dep=vue.2.2.min&err=0" type="text/javascript" src="http://repo.bfw.wiki/bfwrepo/js/bfwone.js"></script>
<script type="text/javascript">
bready(function() {
var app = new Vue({
el: '#app',
data: {
isshow: true
},
created() {
document.addEventListener('click', (e)=> {
//console.log(this.$refs.box);
if (!this.$refs.box.contains(e.target)) {
this.isshow = false;
}
})
}
});
});
</script>
<style>
</style>
</head>
<body>
<div id="app">
<div id="box" ref="box" v-show="isshow" style="width:110px;height:110px;background-color:red"></div>
</div>
</body>
</html>
3、vue click冒泡
给最外层的div加个点击事件 @click="isshow=false"
给点击的元素上面加上:@click.stop="isshow=!isshow" //vue click.stop阻止点击事件继续传播
<!DOCTYPE html>或者给子元素js事件里
<html>
<head>
<meta charset="UTF-8">
<title>BFW NEW PAGE</title>
<script id="bfwone" data="dep=vue.2.2.min&err=0" type="text/javascript" src="http://repo.bfw.wiki/bfwrepo/js/bfwone.js"></script>
<script type="text/javascript">
bready(function() {
var app = new Vue({
el: '#app',
data: {
isshow: true
},
});
});
</script>
<style>
</style>
</head>
<body>
<div id="app" @click="isshow=false">
<div id="box" @click.stop="isshow=!isshow" ref="box" v-show="isshow" style="width:110px;height:110px;background-color:red"></div>
</div>
</body>
</html>
click(e)=>{
e.stopPropagation();//阻止事件冒泡
this.isshow= !this.isshow;
}
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>BFW NEW PAGE</title>
<script id="bfwone" data="dep=vue.2.2.min&err=0" type="text/javascript" src="http://repo.bfw.wiki/bfwrepo/js/bfwone.js"></script>
<script type="text/javascript">
bready(function() {
var app = new Vue({
el: '#app',
data: {
isshow: true
},
methods: {
clickevt: function(e) {
e.stopPropagation(); //阻止事件冒泡
this.isshow = !this.isshow;
}
}
});
});
</script>
<style>
</style>
</head>
<body>
<div id="app" @click="isshow=false">
<div id="box" @click="clickevt" ref="box" v-show="isshow" style="width:110px;height:110px;background-color:red"></div>
</div>
</body>
</html>
网友回复
DLNA与UPnP的区别和不同?
苏超自建抢票app,通过先预约再抽签化解高并发抢票?
python如何让给电脑在局域网中伪装成电视接收手机的投屏图片视频播放?
如何结合python+js如何自己的视频编码与加密播放直播?
python如何在电脑上通过局域网将本地视频或m3u8视频投屏电视播放?
腾讯视频爱奇艺优酷vip电影电视剧视频如何通过python绕过vip收费直接观看?
有没有可免费观看全球电视台直播m3u8地址url的合集?
有没有实现观影自由的免vip影视苹果 CMS V10 API的可用url?
python如何实时检测电脑usb插入检测报警?
如何判断真人操作的鼠标移动直线轨迹与机器操作的轨迹?