搜尋
首頁後端開發php教程vue指令directive

vue指令directive

Dec 07, 2016 pm 04:48 PM

本文為大家分享了vue指令directive的使用方法,供大家參考,具體內容如下

1.指令的註冊

指令跟組件一樣需要註冊才能使用,同樣有兩種方式,一種是全局註冊:

Vue.directive('dirName',function(){
 
  //定义指令
 
});

   


另外一種是局部註冊:

new Vue({
 
  directives:{
 
    dirName:{
 
      //定义指令
 
    }
 
  }
 
});

   


2.的各個生命週期

bind: 只調用一次,指令第一次綁定到元素時調用,用這個鉤子函數可以定義一個在綁定時執行一次的初始化動作。

inserted: 被綁定元素插入父節點時調用(父節點存在即可調用,不必存在於 document 中)。

update: 被綁定元素所在的模板更新時調用,而不論綁定值是否變化。透過比較更新前後的綁定值,可以忽略不必要的模板更新(詳細的鉤子函數參數見下)。

componentUpdated: 被綁定元素所在模板完成一次更新周期時呼叫。

unbind: 只呼叫一次, 指令與元素解綁時呼叫。

在這裡其他幾個都好理解,關於模板更新(update)這裡,本人的理解是:該指令所在的模板有變化而需要重新渲染的時候,比如當一個輸入框的model發生了變化就會觸發指令。當然此處說的比較模糊,具體的還有待研究。

這段程式碼可以實現關於update的使用

<p id="app">
  <input type="text" v-focus="name" v-model="name" :data-name="name">
  <button type="button" @click="name=&#39;zw&#39;">click</button>
 
  <!--当点击按钮的时候name改变,继而触发update中的方法-->
</p>
<script>
 
  Vue.directive(&#39;focus&#39;,{
    bind: function(el, binding){
    console.log(&#39;bind:&#39;,binding.value);
  },
  inserted: function(el, binding){
    console.log(&#39;insert:&#39;,binding.value);
  },
  update: function(el, binding, vnode, oldVnode){
    el.focus();
    console.log(el.dataset.name);//这里的数据是可以动态绑定的
    console.table({
      name:binding.name,
      value:binding.value,
      oldValue:binding.oldValue,
      expression:binding.expression,
      arg:binding.arg,
      modifiers:binding.modifiers,
      vnode:vnode,
      oldVnode:oldVnode
    });
  },
  componentUpdated: function(el, binding){
    console.log(&#39;componentUpdated:&#39;,binding.name);
  }
});
new Vue({
  el:&#39;#app&#39;,
  data:{
    name:&#39;zwzhai&#39;
  }
});
</script>

   


3.鉤子函數的定義

以下是官方提供的幾個參數:

直接操作DOM 。

binding: 一個對象,包含以下屬性:

name: 指令名,不包含 v- 前綴。

value: 指令的綁定值, 例如: v-my-directive="1 + 1", value 的值是 2。
oldValue: 指令綁定的前一個值,僅在 update 和 componentUpdated 鉤子中可用。無論值是否改變都可用。
expression: 綁定值的字串形式。 例如 v-my-directive="1 + 1" , expression 的值是 "1 + 1"。
arg: 傳給指令的參數。例如 v-my-directive:foo, arg 的值是 "foo"。
modifiers: 一個包含修飾符的物件。 例如: v-my-directive.foo.bar, 修飾符物件 modifiers 的值是{ foo: true, bar: true }。
vnode: Vue 編譯產生的虛擬節點,查閱 VNode API 以了解更多詳情。
oldVnode: 上一個虛擬節點,僅在 update 和 componentUpdated 鉤子中可用。


這幾個參數,大家看文檔也能理解,就不多說了,關於bingding的幾個屬性說一下自己的看法,value這個屬性,可以傳字面量,也可以傳單條語句(如上) ,也可以以變數的形式如;arg這裡可以傳一個字串,因為在value去存取綁定值得時候拿到的不是直接寫的那個,也就是說v-focus="name",這個name永遠都是一個變量,需要定義賦值,而arg可以直接訪問該值,如v-focus:foo,那麼在鉤子函數中拿到的就是foo這個字串。

在vue的指令中是不可以雙向資料綁定的,如官方所說:除​​了 el 之外,其它參數都應該是唯讀的,盡量不要修改他們。如果需要在鉤子之間共享數據,建議透過元素的 dataset 來進行。這裡補充下關於dataset的知識:

data-  是html5的新屬性,查了下瀏覽器支援程度,目前的主流瀏覽器都是支援的,IE的話要到10以上。具體的使用:在HTML中以屬性的方式去寫,data-yourname="value",在js中取這個屬性就不用使用getAttribute這個方法,而是直接訪問,ele.dataset.yourname,在js中你也可以新增和刪除,新增:ele.dataset.dessert="yourname",刪除:dette ele.dataset.name。另外,這個屬性可以用來當css選擇器:.class[data-name]:{}。

以上就是vue指令directive的內容,更多相關內容請關注PHP中文網(www.php.cn)!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
超越炒作:評估當今PHP的角色超越炒作:評估當今PHP的角色Apr 12, 2025 am 12:17 AM

PHP在現代編程中仍然是一個強大且廣泛使用的工具,尤其在web開發領域。 1)PHP易用且與數據庫集成無縫,是許多開發者的首選。 2)它支持動態內容生成和麵向對象編程,適合快速創建和維護網站。 3)PHP的性能可以通過緩存和優化數據庫查詢來提升,其廣泛的社區和豐富生態系統使其在當今技術棧中仍具重要地位。

PHP中的弱參考是什麼?什麼時候有用?PHP中的弱參考是什麼?什麼時候有用?Apr 12, 2025 am 12:13 AM

在PHP中,弱引用是通過WeakReference類實現的,不會阻止垃圾回收器回收對象。弱引用適用於緩存系統和事件監聽器等場景,需注意其不能保證對象存活,且垃圾回收可能延遲。

解釋PHP中的__ Invoke Magic方法。解釋PHP中的__ Invoke Magic方法。Apr 12, 2025 am 12:07 AM

\_\_invoke方法允許對象像函數一樣被調用。 1.定義\_\_invoke方法使對象可被調用。 2.使用$obj(...)語法時,PHP會執行\_\_invoke方法。 3.適用於日誌記錄和計算器等場景,提高代碼靈活性和可讀性。

解釋PHP 8.1中的纖維以進行並發。解釋PHP 8.1中的纖維以進行並發。Apr 12, 2025 am 12:05 AM

Fibers在PHP8.1中引入,提升了並發處理能力。 1)Fibers是一種輕量級的並發模型,類似於協程。 2)它們允許開發者手動控制任務的執行流,適合處理I/O密集型任務。 3)使用Fibers可以編寫更高效、響應性更強的代碼。

PHP社區:資源,支持和發展PHP社區:資源,支持和發展Apr 12, 2025 am 12:04 AM

PHP社區提供了豐富的資源和支持,幫助開發者成長。 1)資源包括官方文檔、教程、博客和開源項目如Laravel和Symfony。 2)支持可以通過StackOverflow、Reddit和Slack頻道獲得。 3)開發動態可以通過關注RFC了解。 4)融入社區可以通過積極參與、貢獻代碼和學習分享來實現。

PHP與Python:了解差異PHP與Python:了解差異Apr 11, 2025 am 12:15 AM

PHP和Python各有優勢,選擇應基於項目需求。 1.PHP適合web開發,語法簡單,執行效率高。 2.Python適用於數據科學和機器學習,語法簡潔,庫豐富。

php:死亡還是簡單地適應?php:死亡還是簡單地適應?Apr 11, 2025 am 12:13 AM

PHP不是在消亡,而是在不斷適應和進化。 1)PHP從1994年起經歷多次版本迭代,適應新技術趨勢。 2)目前廣泛應用於電子商務、內容管理系統等領域。 3)PHP8引入JIT編譯器等功能,提升性能和現代化。 4)使用OPcache和遵循PSR-12標準可優化性能和代碼質量。

PHP的未來:改編和創新PHP的未來:改編和創新Apr 11, 2025 am 12:01 AM

PHP的未來將通過適應新技術趨勢和引入創新特性來實現:1)適應云計算、容器化和微服務架構,支持Docker和Kubernetes;2)引入JIT編譯器和枚舉類型,提升性能和數據處理效率;3)持續優化性能和推廣最佳實踐。

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
3 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
3 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
3 週前By尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解鎖Myrise中的所有內容
4 週前By尊渡假赌尊渡假赌尊渡假赌

熱工具

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

WebStorm Mac版

WebStorm Mac版

好用的JavaScript開發工具

MantisBT

MantisBT

Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

SublimeText3 Linux新版

SublimeText3 Linux新版

SublimeText3 Linux最新版

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器