欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Vue 實現(xiàn)顯示/隱藏層的思路(加全局點(diǎn)擊事件)

 更新時間:2019年12月31日 11:27:13   作者:smokelee  
這篇文章主要介紹了Vue 實現(xiàn)顯示/隱藏層的思路(加全局點(diǎn)擊事件),本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下

問題描述:

一個Icon點(diǎn)擊出現(xiàn)菜單,點(diǎn)擊菜單區(qū)域外任何區(qū)域菜單收起。
何為優(yōu)雅的去解決上述問題?

  • 盡可能的采用vue來解決問題
  • 盡可能少的與原生對象發(fā)生交互
  • 代碼干凈、易懂

問題解決思路:

  • 通過Vue的v-show指令決定菜單的顯示、隱藏。
  • 通過Document的全局點(diǎn)擊事件判斷是否該收起
  • 需要優(yōu)雅的解決幾個問題:
  • 禁止點(diǎn)擊事件冒泡。采用VUE的@click.stop來解決問題,請參考下方代碼
  • 優(yōu)雅且安全的移除全局事件監(jiān)聽(只有菜單彈出的時候才去監(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)容要一開始就寫上!
 此處不確定是否是個BUG,不初始style時顯示不正確
 -->
  <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>最后修改時間</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;
   //要特別注意這里,只有菜單顯示的時候才會監(jiān)聽全局點(diǎn)擊事件
   //并且,要設(shè)置為:vue的方法,不能扔到export代碼段外面去。
   //要切記`this`這個變量對應(yīng)的實例是誰
   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 實現(xiàn)顯示/隱藏層的思路(加全局點(diǎn)擊事件),希望對大家有所幫助!

相關(guān)文章

  • vue中組件如何使用vue-quill-editor

    vue中組件如何使用vue-quill-editor

    這篇文章主要介紹了vue中組件如何使用vue-quill-editor問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-01-01
  • 解決vue router使用 history 模式刷新后404問題

    解決vue router使用 history 模式刷新后404問題

    這篇文章主要介紹了解決vue router使用 history 模式刷新后404問題,需要的朋友可以參考下
    2017-07-07
  • Vue開發(fā)Html5微信公眾號的步驟

    Vue開發(fā)Html5微信公眾號的步驟

    這篇文章主要介紹了Vue開發(fā)Html5微信公眾號的步驟,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-04-04
  • 快速處理vue渲染前的顯示問題

    快速處理vue渲染前的顯示問題

    下面小編就為大家分享一篇快速處理vue渲染前的顯示問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-03-03
  • 教你用Vue基礎(chǔ)語法來寫一個五子棋小游戲

    教你用Vue基礎(chǔ)語法來寫一個五子棋小游戲

    在布局上,五子棋相比那些目標(biāo)是隨機(jī)運(yùn)動的游戲,實現(xiàn)起來相對簡單許多,思路也很清晰,下面這篇文章主要給大家介紹了關(guān)于用Vue基礎(chǔ)語法來寫一個五子棋小游戲的相關(guān)資料,需要的朋友可以參考下
    2022-06-06
  • Element-UI?el-table對循環(huán)產(chǎn)生的空白列賦默認(rèn)值方式

    Element-UI?el-table對循環(huán)產(chǎn)生的空白列賦默認(rèn)值方式

    這篇文章主要介紹了Element-UI?el-table對循環(huán)產(chǎn)生的空白列賦默認(rèn)值方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • Vue?3?使用moment設(shè)置顯示時間格式的問題及解決方法

    Vue?3?使用moment設(shè)置顯示時間格式的問題及解決方法

    在Vue?3中,因為過濾器(filter)已經(jīng)被廢棄,取而代之的是全局方法(global?method),本文給大家介紹Vue?3?使用moment設(shè)置顯示時間格式的問題及解決方法,感興趣的朋友一起看看吧
    2023-12-12
  • Vue微信公眾號網(wǎng)頁分享的示例代碼

    Vue微信公眾號網(wǎng)頁分享的示例代碼

    這篇文章主要介紹了Vue微信公眾號網(wǎng)頁分享的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-05-05
  • vue自動路由-單頁面項目(非build時構(gòu)建)

    vue自動路由-單頁面項目(非build時構(gòu)建)

    這篇文章主要介紹了vue自動路由-單頁面項目(非build時構(gòu)建),本文通過實例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-04-04
  • Vue實現(xiàn)注冊頁面的用戶交互詳解

    Vue實現(xiàn)注冊頁面的用戶交互詳解

    這篇文章主要為大家詳細(xì)介紹了Vue實現(xiàn)注冊頁面的用戶交互的相關(guān)知識,文中的示例代碼講解詳細(xì),對我們深入掌握vue有一定的幫助,需要的小伙伴可以參考下
    2023-12-12

最新評論