原始实现
下面是两种常见的模态框的实现方式
方案一:默认 click 都是放在冒泡阶段,只要在内容区域上添加 click 的阻止冒泡即可
<div class="cover" @click="close"> <!-- 阻止冒泡 --> <div class="content" @click.stop>modal content</div> </div>
方案二:通过代码判断点击触发的 DOM 是否在内容区域内
<div class="cover" @click="handleClick"> <div class="content" ref="content">modal content</div> </div> handleClick (e) { let clickOut = true let temp = e.target do { if (temp === this.$refs.content) { clickOut = false break } temp = temp.parentElement } while (temp !== document.documentElement) console.log(clickOut) }
指令实现
上面的代码可以解决全屏的模态框点击外部区域关闭。但是还有一种 Pop 的弹出,这种弹出的外部区域不在本组件内,想要实现这种弹出的点击外部区域关闭用上面的方式二也是可以的,只需把 mounted 阶段把 handleClick 事件添加到 body,在 beforeDestroy 上解绑 body 上的点击时间就就可以了。
如果多个组件需要实现这点击外部区域关闭的效果,可以通过 Vue 的指令来进行封装
实现弹窗
<div class="cover"> <div class="content" v-out-click="close">modal content</div> </div>
实现弹出
<button @click="popIsShow = true">显示气泡</button> <div class="pop" v-if="popIsShow" v-out-click="closePop">I'm pop text</div>
指令代码的具体内容如下。有一点比较难受的是指令里面没有地方能存放变量,只好把把这些变量放到了 DOM 上了。还有就是在使用的时候要加上v-的前缀,指令的名字不用带上v-
import outClick from './directive/out-click.js' Vue.directive(outClick.name, outClick) const KEY_OUT = '_out_click' const KEY_OUT_EVENT = '_out_click_event' const KEY_IN = '_in_click' const KEY_FLAG = '_in_out_flag' function removeEvent(el, binding, vnode) { el.removeEventListener('click', el[KEY_IN], false) window.removeEventListener('click', el[KEY_OUT], false) delete el[KEY_IN] delete el[KEY_OUT] delete el[KEY_OUT_EVENT] delete el[KEY_FLAG] } function initEvent(el, binding, vnode) { // setTimeout 0: 忽略点击外部的按钮初始化该组件时,触发的origin click setTimeout(() => { el[KEY_OUT] = () => outClick(el) el[KEY_IN] = () => inClick(el) el[KEY_OUT_EVENT] = binding.value el.addEventListener('click', el[KEY_IN], false) window.addEventListener('click', el[KEY_OUT], false) }, 0) } function inClick(el) { // 通过事件捕获的顺序作为标志位 // 最好不要使用阻止冒泡来实现,那样会影响其他的click无法触发 el[KEY_FLAG] = '1' } function outClick(el) { if (!el[KEY_FLAG] && el[KEY_OUT_EVENT]) { el[KEY_OUT_EVENT]() } delete el[KEY_FLAG] } export default { name: 'out-click', update: (el, binding, vnode) => { if (binding.value === binding.oldValue) { return } removeEvent(el, binding, vnode) initEvent(el, binding, vnode) }, bind: initEvent, unbind: removeEvent }
以上就是Vue指令实现OutClick的示例的详细内容,更多关于Vue指令实现OutClick的资料请关注小牛知识库其它相关文章!
本文向大家介绍实现一个Vue自定义指令懒加载的方法示例,包括了实现一个Vue自定义指令懒加载的方法示例的使用技巧和注意事项,需要的朋友参考一下 在项目中如果有大量的图片需要加载的时候,就可以考虑使用懒加载了,懒加载其实就是监听浏览器的滚动,当滚动到一定的范围的时候就将图片的真实路径赋给src,然后取消监听。实现的方法也比较简单,可以通过懒加载的插件实现,也可以手写,手写通过vue自定义指令来实现,
本文向大家介绍Vue指令指令大全,包括了Vue指令指令大全的使用技巧和注意事项,需要的朋友参考一下 1. v-text v-text主要用来更新textContent,可以等同于JS的text属性。 这两者等价: 2. v-html 双大括号的方式会将数据解释为纯文本,而非HTML。为了输出真正的HTML,可以用v-html指令。它等同于JS的innerHtml属性。 这个div的内容将会替换成属
本文向大家介绍Vue的土著指令和自定义指令实例详解,包括了Vue的土著指令和自定义指令实例详解的使用技巧和注意事项,需要的朋友参考一下 1.土著指令 当我开始学习Vue的时候,看官网的时候看到了“指令”两个字。我愣住了,what?指令是啥啊?后来继续往下看,像这种什么“v-for”“v-show”“v-if”都叫做指令。等到后来Vue玩的差不多了,开始写项目的时候发现,常见的指令也就那么几个,
本文向大家介绍vue实现局部刷新的实现示例,包括了vue实现局部刷新的实现示例的使用技巧和注意事项,需要的朋友参考一下 利用Vue里面的provide+inject组合(走过路过,不要错过) 使用2.2.0 新增的provide / inject控制<router-view>的显示隐藏 在App.vue中使用provide 在使用局部刷新的组件中使用inject 其他的刷新页面方法 window.
本文向大家介绍Vue 自定义指令实现一键 Copy功能,包括了Vue 自定义指令实现一键 Copy功能的使用技巧和注意事项,需要的朋友参考一下 先看下效果图: 指令是啥? 按照惯例,先请出官方的解释: 指令 (Directives) 是带有 v- 前缀的特殊特性。指令特性的值预期是单个 JavaScript 表达式 (v-for 是例外情况,稍后我们再讨论)。指令的职责是,当表达式的值改变时,将其
本文向大家介绍使用Vue自定义指令实现Select组件,包括了使用Vue自定义指令实现Select组件的使用技巧和注意事项,需要的朋友参考一下 本篇文章教大家写一个非常简单的Select组件,想必很多人都写过Select,毕竟它太常用了,但是本篇文章的示例使用到了Vue的自定义指令,如果你对Vue自定义指令不怎么熟悉的话,本篇文章或许会让您有所收获! 完成的效果图如下: 一、首先,我们简单布局