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

Vue自定義指令寫法與個(gè)人理解

 更新時(shí)間:2019年02月09日 14:11:57   投稿:wdc  
VUE指令是什么,VUE自定義指令又是什么,下面就和大家分享一下個(gè)人對(duì)它們的理解

什么是Vue指令?

指令是一種可以附加到DOM元素的微命令(tiny commands). 它們通常以"v-"作為前綴, 以方便Vue知道你在使用一種特殊的標(biāo)記, 從而確保語(yǔ)法的一致性. 如果你需要對(duì)HTML元素的低級(jí)別(low-level)訪問來控制一些行為, 它們通常很有用.

如果你正在使用Vue(或者Angular), 你可能已經(jīng)很熟悉其中的一些指令, 如: v-if, v-else等等. 我們將從了解一些基礎(chǔ)開始, 但是如果你更愿意直接看例子, 請(qǐng)直接往下滾動(dòng). 這些例子也能很好的讓你理解這些概念.

以下是一些指令的使用方法, 以及對(duì)應(yīng)的例子片段. 這些例子不是規(guī)定性的, 它們只是一些用例. 這里的"例子"實(shí)際上是"指令".

v-example: 這將實(shí)例化一個(gè)指令, 但不接受任何參數(shù). 雖然不帶參數(shù)的指令, 在使用的過程中并不是很靈活, 但是你仍然可以通過這種類型的指令對(duì)DOM元素做一些操作.

v-example="value": 這將傳遞一個(gè)值給指令, 并且該指令根據(jù)該值計(jì)算出要做的操作.

<div v-if="stateExample">I will show up if stateExample is true</div>

v-example="'string'": 這將讓你把'string'作為一個(gè)表達(dá)式.

<p v-html="'<strong>this is an example of a string in some text</strong>'"></p>

v-example:arg="value": 這允許我們傳入一個(gè)參數(shù)給指令. 下面的例子中, 我們綁定到一個(gè)類, 將其樣式化為一個(gè)對(duì)象, 單獨(dú)存儲(chǔ).

<div v-bind:class="someClassObject"></div>

v-example:arg.modifier="value": 這允許我們使用修飾語(yǔ). 下面的例子中, 允許我們?cè)邳c(diǎn)擊事件時(shí), 調(diào)用preventDefault().

<button v-on:submit.prevent="onSubmit"></button>

理解Vue自定義指令

既然我們已經(jīng)大致過了一遍所有的我們所用過的指令類型方法, 讓我們想一想我們?nèi)绾瓮ㄟ^自己編寫的自定義指令來實(shí)現(xiàn)它們? 使用自定義指令的一個(gè)很好的例子是滾動(dòng)事件, 讓我們看看如何實(shí)現(xiàn)它.

首先, 最基本的是如何創(chuàng)建一個(gè)全局的指令. (是的, 它什么也不做.) 僅僅是創(chuàng)建了一個(gè)指令.

Vue.directive('tack');

HTML:

<p v-tack>This element has a directive on it</p>

我們有幾個(gè)可用的鉤子, 每個(gè)鉤子可以選擇一些參數(shù). 鉤子如下:

bind: 一旦指令附加到元素時(shí)觸發(fā)
inserted: 一旦元素被添加到父元素時(shí)觸發(fā)
update: 每當(dāng)元素本身更新(但是子元素還未更新)時(shí)觸發(fā)
componentUpdate: 每單組件和子組件被更新時(shí)觸發(fā)
unbind: 一旦指令被移除時(shí)觸發(fā)

就個(gè)人而言, bind和update也許是這五個(gè)里面最有用的兩個(gè)鉤子了.
每個(gè)鉤子都有el, binding, 和vnode參數(shù)可用. update和componentUpdated鉤子還暴露了oldVnode, 以區(qū)分傳遞的舊值和較新的值.

el, 跟你所期待的一樣, 就是所綁定的元素. binding是一個(gè)保護(hù)傳入鉤子的參數(shù)的對(duì)象. 有很多可用的參數(shù), 包括name, value, oldValue, expression, arguments, arg及修飾語(yǔ). vnode有一個(gè)更不尋常的用例, 它可用于你需要直接引用到虛擬DOM中的節(jié)點(diǎn). binding和vnode都應(yīng)該被視為只讀.

綁定一個(gè)自定義指令

既然我們已經(jīng)知道了這一點(diǎn), 就可以開始研究如何在實(shí)際中使用一個(gè)自定義指令. 讓我們完善剛才所創(chuàng)建的第一個(gè)指令, 讓它變得有用:

Vue.directive('tack', {
  bind(el, binding, vnode) {
    el.style.position = 'fixed'
  }
});

在HTML元素中:

<p v-tack>I will now be tacked onto the page</p>

毫無疑問, 它完全可以按照我們所希望的工作. 但是它還不夠靈活, 如果我們可以傳入一個(gè)值, 然后直接更新或者重用這個(gè)指令就好了. 例如, 我們想為這個(gè)元素指定一個(gè)值, 表示這個(gè)元素離頂部多遠(yuǎn)(多少個(gè)像素), 我們可以這樣寫(在CODEPEN上查看):


// JS
Vue.directive('tack', {
  bind(el, binding, vnode){
    el.style.position = 'fixed';
    el.style.top = binding.value + 'px';
  }
});

// HTML
<div id="app">
  <p>Scroll down the page</p>
  <p v-tack="70">Stick me 70px from the top of the page</p>
</div>

假設(shè)我們想要區(qū)分從頂部或者左側(cè)偏移70px, 我們可以通過傳遞一個(gè)參數(shù)來做到這一點(diǎn)(在CODEPEN上查看):


// JS
Vue.directive('tack', {
  bind(el, binding, vnode) {
    el.style.position = 'fixed';
    const s = (binding.arg === 'left' ? 'left' : 'top');
    el.style[s] = binding.value + 'px';
  }
});

// HTML
<p v-tack:left="70">I'll now be offset from the left instead of the top</p>

當(dāng)然, 你可以同時(shí)傳入不止一個(gè)值. 你可以像使用標(biāo)準(zhǔn)指令一樣簡(jiǎn)單的使用自定義指令(在CODEPEN上查看):

// JS
Vue.directive('tack', {
  bind(el, binding, vnode) {
    el.style.position = 'fixed';
    el.style.top = binding.value.top + 'px';
    el.style.left = binding.value.left + 'px';
  }
});

// HTML
<p v-tack="{top: '40', left: '100'}">Stick me 40px from the top of the page and 100px from the left of the page</p>

基于我們的自定義指令, 我們可以創(chuàng)建和修改方法, 從而創(chuàng)建更為復(fù)雜的自定義指令. 這里, 我們將做一個(gè)waypoints-like例子, 用少量的代碼實(shí)現(xiàn)特定滾動(dòng)事件觸發(fā)的動(dòng)畫效果(在CODEPEN上查看):

// JS
Vue.directive('scroll', {
  inserted: function(el, binding) {
    let f = function(evt) {
      if(binding.value(evt, el)) {
        window.removeEventListener('scroll', f);
      }
    };
    window.addEventListener('scroll', f);
  }
});

// main app
new Vue({
  el: "#app",
  methods: {
    handleScroll: function(evt, el) {
      if(window.scrollY > 50) {
        TweenMax.to(el, 1.5, {
          y: -10,
          opacity: 1,
          ease: Sine.easeOut
        });
      }
      
      return window.scrollY > 100;
    }
  }
});

// HTML
<div class="box" v-scroll="handleScroll">
  <p>Lorem ipsum dolor sit amet, consectetur adipisicing elit. A atque amet harum aut ab veritatis earum porro praesentium ut corporis. Quasi provident dolorem officia iure fugiat, eius mollitia sequi quisquam.</p>
</div>

為了讓大家看得更清楚, 在這個(gè)代碼片段中, 我們盡可能的保證它的簡(jiǎn)單易讀. 在實(shí)際的APP中, 你可以構(gòu)建非常友好的, 并且非常靈活的, 適合整個(gè)團(tuán)隊(duì)使用的自定義指令.

在實(shí)際的構(gòu)建中, 我會(huì)將指令代碼放在"main.js"文件中, 該文件位于"src"目錄的根目錄下(如果你使用的是Vue-cli構(gòu)建工具), 那么"App.vue"以及組件目錄中的所有的.vue文件都可以訪問它. 當(dāng)然, 還要其他方法可以使用它, 但是我發(fā)現(xiàn)對(duì)于整個(gè)應(yīng)用程序來說, 這是最靈活的實(shí)現(xiàn)方式.

以上就是個(gè)人對(duì)Vue自定義指令的理解,希望對(duì)大家有所幫助

相關(guān)文章

  • vue-cli 如何打包上線的方法示例

    vue-cli 如何打包上線的方法示例

    這篇文章主要介紹了vue-cli 如何打包上線的方法示例,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-05-05
  • Vue.js 加入高德地圖的實(shí)現(xiàn)代碼

    Vue.js 加入高德地圖的實(shí)現(xiàn)代碼

    這篇文章主要介紹了Vue.js 加入高德地圖的實(shí)現(xiàn)方法,本文結(jié)合示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-12-12
  • Vue實(shí)現(xiàn)訂單支付倒計(jì)時(shí)功能

    Vue實(shí)現(xiàn)訂單支付倒計(jì)時(shí)功能

    這篇文章主要給大家介紹了Vue實(shí)現(xiàn)訂單支付倒計(jì)時(shí)功能,倒計(jì)時(shí)這要運(yùn)用在創(chuàng)建訂單后15分鐘內(nèi)進(jìn)行支付,否則訂單取消,本文結(jié)合示例代碼給大家詳細(xì)講解,需要的朋友可以參考下
    2023-08-08
  • Vue中實(shí)現(xiàn)滾動(dòng)加載與無限滾動(dòng)

    Vue中實(shí)現(xiàn)滾動(dòng)加載與無限滾動(dòng)

    本文主要介紹了Vue中實(shí)現(xiàn)滾動(dòng)加載與無限滾動(dòng),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-06-06
  • 幾分鐘弄懂Vuex的五大屬性和使用方式

    幾分鐘弄懂Vuex的五大屬性和使用方式

    這篇文章主要介紹了幾分鐘弄懂Vuex的五大屬性和使用方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-10-10
  • Vue監(jiān)視數(shù)據(jù)的原理詳解

    Vue監(jiān)視數(shù)據(jù)的原理詳解

    這篇文章主要為大家詳細(xì)介紹了Vue監(jiān)視數(shù)據(jù)的原理,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-02-02
  • vue3.0 的 Composition API 的使用示例

    vue3.0 的 Composition API 的使用示例

    這篇文章主要介紹了vue3.0 的 Composition API 的使用示例,幫助大家更好的理解和學(xué)習(xí)vue,感興趣的朋友可以了解下
    2020-10-10
  • vue引入element-ui之后,頁(yè)面是空白的問題及解決

    vue引入element-ui之后,頁(yè)面是空白的問題及解決

    這篇文章主要介紹了vue引入element-ui之后,頁(yè)面是空白的問題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-01-01
  • vue項(xiàng)目中引入noVNC遠(yuǎn)程桌面的方法

    vue項(xiàng)目中引入noVNC遠(yuǎn)程桌面的方法

    下面小編就為大家分享一篇vue項(xiàng)目中引入noVNC遠(yuǎn)程桌面的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2018-03-03
  • 淺析對(duì)Vue中keep-alive緩存組件的理解

    淺析對(duì)Vue中keep-alive緩存組件的理解

    <keep-alive> 是一個(gè)抽象組件,用于將其內(nèi)部的組件保留在內(nèi)存中,而不會(huì)重新渲染,這意味著當(dāng)組件在<keep-alive> 內(nèi)部切換時(shí),其狀態(tài)將被保留,而不是被銷毀和重新創(chuàng)建,這篇文章主要介紹了Vue中的keep-alive緩存組件的理解,需要的朋友可以參考下
    2024-01-01

最新評(píng)論