我们利用 Vue.js 的自定义指令能力,来实现一个自定义下拉菜单功能。描述如下:
1基础版
html:
<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8"> <title>Title</title> <link rel="stylesheet" type="text/css" href="style.css" rel="external nofollow" ></head><body> <div id="app" v-cloak> <div class="main" v-outside-click="close"> <button @click="isShow=!isShow">点击</button> <div class="dropDown" v-show="isShow"> <p>零售新物种:药店和便利店合体之后</p> </div> </div> </div><script src="https://cdn.bootcss.com/vue/2.2.2/vue.min.js"></script><script src="index.js"></script></body></html>
我们为按钮绑定了 isShow 变量,当点击按钮时,显示 class="dropDown" 的 div 元素。
js:
Vue.directive('outside-click', { bind: function (el, binding, vnode) { //定义点击函数 function clickHandler(e) { if (el.contains(e.target)) {//如果点击区域在所在指令元素内部,则直接返回 return false; } if (binding.expression) {//如果定义了表达式,则执行表达式中的函数 binding.value(e); } } el.vueOutsideClick = clickHandler; document.addEventListener('click', clickHandler);//绑定到 document 的点击事件 }, unbind: function (el, binding, vnode) { document.removeEventListener('click', el.vueOutsideClick);//解绑 delete el.vueOutsideClick;//销毁 }});var app = new Vue({ el: '#app', data: { isShow: false }, methods: { close: function () { this.isShow = false; } }});
bind 中:
unbind 中:
css:
[v-cloak] { display: none;}.main { width: 125px;}button { display: block; width: 100%; color: #ffffff; background-color: #99CC66; border: 0; padding: 6px; text-align: center; font-size: 12px; border-radius: 4px; cursor: pointer; position: relative; outline: none;}button:active { top: 1px; left: 1px;}.dropDown { width: 100%; height: 150px; margin: 5px 0; font-size: 12px; background-color: #ffffff; border-radius: 4px; box-shadow: 0 1px 6px rgba(0, 0, 0, .2);}.dropDown p { display: inline-block; padding: 6px;}
新闻热点
疑难解答
图片精选