内射老阿姨1区2区3区4区_久久精品人人做人人爽电影蜜月_久久国产精品亚洲77777_99精品又大又爽又粗少妇毛片

詳解vue中點(diǎn)擊空白處隱藏div的實(shí)現(xiàn)(用指令實(shí)現(xiàn))

簡單想應(yīng)該怎么實(shí)現(xiàn)?

創(chuàng)新互聯(lián)是一家專注于成都網(wǎng)站制作、成都網(wǎng)站設(shè)計(jì)與策劃設(shè)計(jì),元江縣網(wǎng)站建設(shè)哪家好?創(chuàng)新互聯(lián)做網(wǎng)站,專注于網(wǎng)站建設(shè)十多年,網(wǎng)設(shè)計(jì)領(lǐng)域的專業(yè)建站公司;建站業(yè)務(wù)涵蓋:元江縣等地區(qū)。元江縣做網(wǎng)站價(jià)格咨詢:13518219792

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

簡單介紹vue指令

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

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

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

詳解vue中點(diǎn)擊空白處隱藏div的實(shí)現(xiàn)(用指令實(shí)現(xiàn))

代碼實(shí)現(xiàn)

創(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) {
  // 這里判斷點(diǎn)擊的元素是否是本身,是本身,則返回
      if (el.contains(e.target)) {
        return false;
  }
  // 判斷指令中是否綁定了函數(shù)
      if (binding.expression) {
  // 如果綁定了函數(shù) 則調(diào)用那個(gè)函數(shù),此處binding.value就是handleClose方法
        binding.value(e);
      }
 }
 // 給當(dāng)前元素綁定個(gè)私有變量,方便在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>

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。

分享文章:詳解vue中點(diǎn)擊空白處隱藏div的實(shí)現(xiàn)(用指令實(shí)現(xiàn))
文章地址:http://www.rwnh.cn/article16/igiogg.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站內(nèi)鏈、定制網(wǎng)站、關(guān)鍵詞優(yōu)化網(wǎng)站設(shè)計(jì)公司、網(wǎng)站設(shè)計(jì)、手機(jī)網(wǎng)站建設(shè)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

成都定制網(wǎng)站建設(shè)
宜君县| 万安县| 长宁县| 湘潭市| 象山县| 邯郸市| 杨浦区| 南宫市| 富顺县| 阳春市| 吴桥县| 丹寨县| 乐安县| 天津市| 镇巴县| 高密市| 高碑店市| 女性| 文成县| 武安市| 江西省| 富裕县| 崇左市| 博爱县| 通州区| 白朗县| 磐安县| 龙川县| 清原| 平塘县| 巧家县| 壤塘县| 汝南县| 普宁市| 城市| 漾濞| 溆浦县| 城步| 比如县| 鄯善县| 盈江县|