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

詳解vue中點擊空白處隱藏div的實現(用指令實現)

 更新時間:2018年04月19日 11:41:47   作者:jaxQin  
本篇文章主要介紹了詳解vue中點擊空白處隱藏div的實現(用指令實現),小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

簡單想應該怎么實現?

1、肯定是給document增加一個click事件監(jiān)聽
2、當發(fā)生click事件的時候判斷是否點擊的當前對象
結合著本思路和指令咱們來實現。

簡單介紹vue指令

一個指令定義對象可以提供如下幾個鉤子函數 (均為可選):

  1. bind:只調用一次,指令第一次綁定到元素時調用。在這里可以進行一次性的初始化設置。
  2. inserted:被綁定元素插入父節(jié)點時調用 (僅保證父節(jié)點存在,但不一定已被插入文檔中)。
  3. update:所在組件的 VNode 更新時調用,但是可能發(fā)生在其子 VNode 更新之前。指令的值可能發(fā)生了改變,也可能沒有。但是你可以通過比較更新前后的值來忽略不必要的模板更新 (詳細的鉤子函數參數見下)。
  4. componentUpdated:指令所在組件的 VNode 及其子 VNode 全部更新后調用。
  5. unbind:只調用一次,指令與元素解綁時調用。

接下來我們來看一下鉤子函數的參數 (即 el、binding、vnode 和 oldVnode)。

代碼實現

創(chuàng)建指令對象,分析放在代碼中

<template>
 <div>
 <div class="show" v-show="show" v-clickoutside="handleClose">
  顯示
 </div>
 </div>
</template>

<script>
const clickoutside = {
 // 初始化指令
  bind(el, binding, vnode) {
    function documentHandler(e) {
  // 這里判斷點擊的元素是否是本身,是本身,則返回
      if (el.contains(e.target)) {
        return false;
  }
  // 判斷指令中是否綁定了函數
      if (binding.expression) {
  // 如果綁定了函數 則調用那個函數,此處binding.value就是handleClose方法
        binding.value(e);
      }
 }
 // 給當前元素綁定個私有變量,方便在unbind中可以解除事件監(jiān)聽
    el.__vueClickOutside__ = documentHandler;
    document.addEventListener('click', documentHandler);
  },
  update() {},
  unbind(el, binding) {
 // 解除事件監(jiān)聽
    document.removeEventListener('click', el.__vueClickOutside__);
    delete el.__vueClickOutside__;
  },
};
export default {
  name: 'HelloWorld',
  data() {
    return {
      show: true,
    };
  },
  directives: {clickoutside},
  methods: {
    handleClose(e) {
      this.show = false;
    },
  },
};
</script>

<!-- Add "scoped" attribute to limit CSS to this component only -->
<style scoped>
.show {
  width: 100px;
  height: 100px;
  background-color: red;
}
</style>

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • Vue實現輸入框@功能的示例代碼

    Vue實現輸入框@功能的示例代碼

    這篇文章主要為大家介紹了如何利用Vue實現輸入框@功能,文中的示例代碼講解詳細,對我們學習Vue有一定的幫助,感興趣的可以學習一下
    2022-05-05
  • 詳解Vue中是如何實現cache緩存的

    詳解Vue中是如何實現cache緩存的

    這篇文章分享一個比較有意思的東西,那就是Vue中如何實現cache緩存的,文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起學習一下
    2023-07-07
  • vue?LogicFlow更多配置選項示例詳解

    vue?LogicFlow更多配置選項示例詳解

    這篇文章主要為大家介紹了vue?LogicFlow更多配置選項詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-01-01
  • vue前端代碼如何通過maven打成jar包運行

    vue前端代碼如何通過maven打成jar包運行

    這篇文章主要介紹了vue前端代碼如何通過maven打成jar包運行問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-01-01
  • vue實現輸入一位數字轉漢字功能

    vue實現輸入一位數字轉漢字功能

    這篇文章主要介紹了vue實現輸入一位數字轉漢字功能,本文通過實例代碼給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-12-12
  • 解決vue路由后界面沒有變化,但是鏈接有的問題

    解決vue路由后界面沒有變化,但是鏈接有的問題

    今天小編就為大家分享一篇解決vue路由后界面沒有變化,但是鏈接有的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-09-09
  • vue實現將圖像文件轉換為base64

    vue實現將圖像文件轉換為base64

    這篇文章主要介紹了vue實現將圖像文件轉換為base64,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-02-02
  • 關于Vue的URL轉跳與參數傳遞方式

    關于Vue的URL轉跳與參數傳遞方式

    這篇文章主要介紹了關于Vue的URL轉跳與參數傳遞方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-03-03
  • vue中使用heatmapjs的示例代碼(結合百度地圖)

    vue中使用heatmapjs的示例代碼(結合百度地圖)

    這篇文章主要介紹了vue中使用heatmapjs的示例代碼(結合百度地圖),小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-09-09
  • 一文搞懂Vue3.2中setup語法糖使用

    一文搞懂Vue3.2中setup語法糖使用

    在vue3版本中,引入了一個新的函數,叫做setup。本文將通過實例為大家詳細講講Vue3.2中setup語法糖的使用,感興趣的小伙伴可以了解一下
    2022-07-07

最新評論