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://www.jygsgssxh.com/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)頁面的局部加載
 


