手动监听判断

<template>
<div>
<span ref="projectButton">
<el-popover v-model="visible" trigger="manual" placement="bottom" @show="show" @hide="hide">
<p>啦啦啦</p>
<el-button slot="reference" type="primary" @click="visible = !visible">show</el-button>
</el-popover>
</span>
</div>
</template>
<script>
export default {
data() {
return {
visible: false,
}
},
methods: {
show() {
document.addEventListener('click', this.hidePanel, false)
},
hide() {
document.removeEventListener('click', this.hidePanel, false)
},
hidePanel(e) {
if (!this.$refs.projectButton.contains(e.target)) {
this.visible = false
this.hide()
}
},
},
}
</script>

自定义指令

<template>
<div>
<div class="show" v-show="show" v-clickoutside="handleClose">
显示
</div>
</div>
</template>
<script>
const clickoutside = {
// 初始化指令
bind(el, binding, vnode) {
function documentHandler(e) {
// 这里判断点击的元素是否是本身,是本身,则返回
if (el.contains(e.target)) {
return false
}
// 判断指令中是否绑定了函数
if (binding.expression) {
// 如果绑定了函数 则调用那个函数,此处binding.value就是handleClose方法
binding.value(e)
}
}
// 给当前元素绑定个私有变量,方便在unbind中可以解除事件监听
el.__vueClickOutside__ = documentHandler
document.addEventListener('click', documentHandler)
},
update() {},
unbind(el, binding) {
// 解除事件监听
document.removeEventListener('click', el.__vueClickOutside__)
delete el.__vueClickOutside__
},
}
export default {
name: 'HelloWorld',
data() {
return {
show: true,
}
},
directives: { clickoutside },
methods: {
handleClose(e) {
this.show = false
},
},
}
</script>
<!-- Add "scoped" attribute to limit CSS to this component only -->
<style scoped>
.show {
width: 100px;
height: 100px;
background-color: red;
}
</style>

vue 指令

bind:只调用一次,指令第一次绑定到元素时调用。在这里可以进行一次性的初始化设置。

inserted:被绑定元素插入父节点时调用 (仅保证父节点存在,但不一定已被插入文档中)。

update:所在组件的 VNode 更新时调用,但是可能发生在其子 VNode 更新之前。指令的值可能发生了改变,也可能没有。但是你可以通过比较更新前后的值来忽略不必要的模板更新 (详细的钩子函数参数见下)。

componentUpdated:指令所在组件的 VNode 及其子 VNode 全部更新后调用。

unbind:只调用一次,指令与元素解绑时调用。

遮罩

<template>
<div>
<div class="mask" v-if="showModal" @click="showModal=false"></div>
<div class="pop" v-if="showModal">
<button @click="showModal=false" class="btn">点击出现弹框</button>
</div>
<button @click="showModal=true" class="btn">点击出现弹框</button>
</div>
</template> <script>
export default {
data() {
return {
showModal: false,
}
},
}
</script> <style scoped>
.mask {
background-color: #000;
opacity: 0.3;
position: fixed;
top: 0;
left: 0;
width: 100%;
height: 100%;
z-index: 1;
}
.pop {
background-color: #fff;
position: fixed;
top: 100px;
left: 300px;
width: calc(100% - 600px);
height: calc(100% - 200px);
z-index: 2;
}
.btn {
background-color: #fff;
border-radius: 4px;
border: 1px solid blue;
padding: 4px 12px;
}
</style>

转自:https://www.jianshu.com/p/ec87b4473758

 

最新文章

  1. SQL分页
  2. dedecms \plus\guestbook.php SQL Injection Vul By \plus\guestbook\edit.inc.php
  3. Jocket
  4. MySQL添加字段和修改字段的方法
  5. 转: Jsp9个内置对象详解
  6. delphi 01设置 字体属性
  7. BZOJ_1022_[SHOI2008]_小约翰的游戏John_(博弈论_反Nim游戏)
  8. FIO工具常用参数
  9. VS编辑代码的时候,都会自动在资源浏览器里将文件所在项目展开
  10. 修改ORACLE的语言参数
  11. CodeForces 722A
  12. Problem 2144 Shooting Game fzu
  13. Libevent源码分析 (1) hello-world
  14. BZOJ 3270: 博物馆 [概率DP 高斯消元]
  15. Java项目中启动Tomcat报错invalid LOC header
  16. select 的选中问题
  17. LeetCode88.合并两个有序数组
  18. 获取C++类成员虚函数地址
  19. Python3基础 tuple 创建空元组或者只有一个元素的元组 并 用乘法成倍扩充
  20. iOS学习笔记(4)——显示单组件选取器

热门文章

  1. ArcGIS工具 - 按要素裁切数据库
  2. Jekyll + GitHub Pages + Vercel纯免费搭建独立博客
  3. DVWA靶场实战(三)——CSRF
  4. [Leetcode]设计循环队列
  5. 真正“搞”懂HTTP协议08之重定向
  6. ElasticSearch必知必会-进阶篇
  7. MAC实用操作记录---使用命令执行文件上传下载解压打包与解包
  8. SpringBoot学习笔记 - 构建、简化原理、快速启动、配置文件与多环境配置、技术整合案例
  9. 12月6日内容总结——BOM、DOM、两者查找标签的方式和操作标签的方式、操作class和css的方法、事件、jQuery类库
  10. Kubernetes(k8s)控制器(三):ReplicationController