Vue 實(shí)現(xiàn)顯示/隱藏層的思路(加全局點(diǎn)擊事件)
問題描述:
一個(gè)Icon點(diǎn)擊出現(xiàn)菜單,點(diǎn)擊菜單區(qū)域外任何區(qū)域菜單收起。
何為優(yōu)雅的去解決上述問題?
- 盡可能的采用vue來解決問題
- 盡可能少的與原生對(duì)象發(fā)生交互
- 代碼干凈、易懂
問題解決思路:
- 通過Vue的v-show指令決定菜單的顯示、隱藏。
- 通過Document的全局點(diǎn)擊事件判斷是否該收起
- 需要優(yōu)雅的解決幾個(gè)問題:
- 禁止點(diǎn)擊事件冒泡。采用VUE的@click.stop來解決問題,請(qǐng)參考下方代碼
- 優(yōu)雅且安全的移除全局事件監(jiān)聽(只有菜單彈出的時(shí)候才去監(jiān)聽)
document的事件添加
HTML
<template> <div class="dir"> <!-- 按鈕,特別注意@click.stop用于禁止消息冒泡 --> <span title="排序" id="sort_by" @click.stop="onSortClick()" class="icons">按鈕</span><br/> <!-- 菜單 v-show設(shè)置變量 showSortmenu,style的內(nèi)容要一開始就寫上! 此處不確定是否是個(gè)BUG,不初始style時(shí)顯示不正確 --> <ul class="menu" id="sort_by_menu" v-show="showSortmenu" style="display: block;"> <li sort="title"> <span>標(biāo)題</span> </li> <li sort="lastModify"> <span>最后修改時(shí)間</span> </li> <li sort="free"> <span>自定義排序</span> </li> </ul> </div> </template>
JavaScript
<script> export default { name: "demo2", data() { return { showSortmenu: false }; }, props: {}, methods: { //接收按鈕點(diǎn)擊事件@click.stop,禁止冒泡 onSortClick: function() { //設(shè)置bool值, this.showSortmenu = !this.showSortmenu; //要特別注意這里,只有菜單顯示的時(shí)候才會(huì)監(jiān)聽全局點(diǎn)擊事件 //并且,要設(shè)置為:vue的方法,不能扔到export代碼段外面去。 //要切記`this`這個(gè)變量對(duì)應(yīng)的實(shí)例是誰 if (this.showSortmenu) { document.addEventListener("click", this.onGlobalClick); } }, //全局監(jiān)聽點(diǎn)擊事件 onGlobalClick(e) { //判斷全局被點(diǎn)中的控件的className,不同就是菜單外點(diǎn)擊 if (e.target.className != "sort_by_menu") { this.showSortmenu = false; //這里要注意啊!!!!一定要記得移除監(jiān)聽事件!?。。?! document.removeEventListener("click", this.onGlobalClick); } } }, mounted() {}, }; </script>
總結(jié)
以上所述是小編給大家介紹的Vue 實(shí)現(xiàn)顯示/隱藏層的思路(加全局點(diǎn)擊事件),希望對(duì)大家有所幫助!
上一篇:JS三級(jí)聯(lián)動(dòng)代碼格式實(shí)例詳解
欄 目:JavaScript
下一篇:JavaScript監(jiān)聽觸摸事件代碼實(shí)例
本文標(biāo)題:Vue 實(shí)現(xiàn)顯示/隱藏層的思路(加全局點(diǎn)擊事件)
本文地址:http://mengdiqiu.com.cn/a1/JavaScript/9346.html
您可能感興趣的文章
- 04-02java后端代碼分頁 java后端實(shí)現(xiàn)分頁page
- 01-10Echarts實(shí)現(xiàn)單條折線可拖拽效果
- 01-10在Vue項(xiàng)目中使用Typescript的實(shí)現(xiàn)
- 01-10js實(shí)現(xiàn)上傳圖片并顯示圖片名稱
- 01-10Vue中使用Lodop插件實(shí)現(xiàn)打印功能的簡(jiǎn)單方法
- 01-10echarts實(shí)現(xiàn)折線圖的拖拽效果
- 01-10d3.js實(shí)現(xiàn)圖形縮放平移
- 01-10小程序簡(jiǎn)單兩欄瀑布流效果的實(shí)現(xiàn)
- 01-10H5實(shí)現(xiàn)手機(jī)拍照和選擇上傳功能
- 01-10Echarts實(shí)現(xiàn)多條折線可拖拽效果


閱讀排行
- 1C語言 while語句的用法詳解
- 2java 實(shí)現(xiàn)簡(jiǎn)單圣誕樹的示例代碼(圣誕
- 3利用C語言實(shí)現(xiàn)“百馬百擔(dān)”問題方法
- 4C語言中計(jì)算正弦的相關(guān)函數(shù)總結(jié)
- 5c語言計(jì)算三角形面積代碼
- 6什么是 WSH(腳本宿主)的詳細(xì)解釋
- 7C++ 中隨機(jī)函數(shù)random函數(shù)的使用方法
- 8正則表達(dá)式匹配各種特殊字符
- 9C語言十進(jìn)制轉(zhuǎn)二進(jìn)制代碼實(shí)例
- 10C語言查找數(shù)組里數(shù)字重復(fù)次數(shù)的方法
本欄相關(guān)
- 04-02javascript點(diǎn)線,點(diǎn)線的代碼
- 04-02javascript潛力,javascript強(qiáng)大嗎
- 04-02javascript替換字符串,js字符串的替換
- 04-02javascript移出,js 移入移出
- 04-02包含javascript舍的詞條
- 04-02javascript并行,深入理解并行編程 豆瓣
- 04-02javascript匿名,js匿名方法
- 04-02javascript警報(bào),JavaScript警告
- 04-02javascript遮蓋,JavaScript遮蓋PC端頁面
- 04-02javascript前身,javascript的前身
隨機(jī)閱讀
- 08-05dedecms(織夢(mèng))副欄目數(shù)量限制代碼修改
- 01-10SublimeText編譯C開發(fā)環(huán)境設(shè)置
- 08-05織夢(mèng)dedecms什么時(shí)候用欄目交叉功能?
- 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文
- 01-10delphi制作wav文件的方法
- 01-10C#中split用法實(shí)例總結(jié)
- 04-02jquery與jsp,用jquery
- 01-10使用C語言求解撲克牌的順子及n個(gè)骰子
- 08-05DEDE織夢(mèng)data目錄下的sessions文件夾有什
- 01-11ajax實(shí)現(xiàn)頁面的局部加載