91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

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

發布時間:2020-09-03 18:12:54 來源:腳本之家 閱讀:179 作者:jaxQin 欄目:web開發

簡單想應該怎么實現?

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

簡單介紹vue指令

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

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

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

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

代碼實現

創建指令對象,分析放在代碼中

<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中可以解除事件監聽
    el.__vueClickOutside__ = documentHandler;
    document.addEventListener('click', documentHandler);
  },
  update() {},
  unbind(el, binding) {
 // 解除事件監聽
    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>

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

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

陇西县| 马公市| 柘城县| 桂东县| 溧阳市| 五原县| 沅江市| 鄯善县| 孟州市| 镇雄县| 焉耆| 望都县| 新沂市| 宜兴市| 龙井市| 常德市| 绥芬河市| 东乌珠穆沁旗| 淮安市| 汉源县| 马公市| 连江县| 册亨县| 巴彦县| 宁化县| 廉江市| 沾益县| 镇安县| 边坝县| 马关县| 满洲里市| 福安市| 宿松县| 白山市| 伊春市| 阜宁县| 新民市| 博湖县| 淳化县| 岑溪市| 公主岭市|