前端框架Vue.js中Directive知識(shí)詳解
Directive
看上去雖然和Angular中的定義類似,Directive 都是對(duì)DOM功能的一種拓展,但是 Vue 的 Directive 要弱的多。因?yàn)?Vue Component 其實(shí)本來(lái)就會(huì)包含對(duì)DOM的操作,所以大多數(shù)時(shí)候我們寫一個(gè)通用組件都是一個(gè)Component 而不是一個(gè) Directive,而 在 Angular 我們寫一個(gè)通用的組件一般都是一個(gè) Directive 。
所以我說(shuō) Vue 的 Directive 相比于 Angular 要弱的多,也可以說(shuō)純粹的多,他就是對(duì) DOM 功能的一個(gè)拓展,而不是為了封裝和DOM相關(guān)的邏輯。有興趣可以通過(guò)對(duì)比這兩個(gè)UI庫(kù)就能明白:
•Vux https://github.com/airyland/vux
•Angular Bootstrap https://github.com/angular-ui/bootstrap
對(duì)比就會(huì)發(fā)現(xiàn),其實(shí)在 Vue 中我們封裝一個(gè)通用的組件(其實(shí)不管是不是通用)都是一個(gè) Component,但是在 Angular 中卻是一個(gè) Directive,因?yàn)?Angular 中的 Controller 其實(shí)只能創(chuàng)建一個(gè) $scope 作用域??梢院?jiǎn)單的認(rèn)為在 Vue Directive = Angular Directive + Controller。前面講到過(guò) Vue 很多設(shè)計(jì)都和Angular2類似,Vue 中的 Directive 基本可以等價(jià)于 Angular2 的 Directive,但是千萬(wàn)不要和 Angular 中的 Directive 搞混了。
為了避免誤導(dǎo),所以后面不再拿 Angular Directive 作對(duì)比了。
生命周期
生命周期分為三步:
•bind 第一次綁定到DOM元素上的時(shí)候觸發(fā)
•update bind完成之后立刻觸發(fā),以后每當(dāng)參數(shù)更新的時(shí)候都會(huì)觸發(fā)
•unbind 解除和DOM元素的綁定時(shí)觸發(fā)
API 簡(jiǎn)潔到哭。。。
其中 update 是最重要的,也就是當(dāng) Directive 接收到一個(gè)值的更新的時(shí)候就會(huì)執(zhí)行對(duì)應(yīng)的代碼。update函數(shù)接收的參數(shù)就是用戶通過(guò) Attr 傳入的值。
我們下面實(shí)現(xiàn)一個(gè)簡(jiǎn)單的 Directive,它的作用是對(duì) Todo List 輸入的內(nèi)容進(jìn)行校驗(yàn)(表單校驗(yàn))。Directive 基本結(jié)構(gòu)如下:
Vue.directive("minlength", { bind: function() { }, update: function(value) { }, unbind: function() { } });
然后,我們需要在用戶輸入的時(shí)候進(jìn)行校驗(yàn),這里實(shí)現(xiàn)一個(gè)簡(jiǎn)單的 minlength 校驗(yàn),代碼如下:
Vue.directive("minlength", { bind: function() { var self = this; var el = this.el; el.addEventListener("keydown", function(e) { if(e.keyCode === 13) { if(el.value.length < self.minlength) { e.preventDefault(); } } }); var submit = el.parentNode.querySelector("button, [type='submit']"); submit.disabled = true; el.addEventListener("keyup", function(e) { submit.disabled = (el.value.length < self.minlength); }); }, update: function(value) { this.minlength = parseInt(value); }, unbind: function() { } });
基本邏輯就在在 bind 階段的時(shí)候就綁定事件,然后根據(jù) update 時(shí)候傳入的 minlength 值來(lái)進(jìn)行判斷。
目前看,Directive 應(yīng)該就是為了實(shí)現(xiàn)類似的功能存在的,當(dāng)然還有很多細(xì)枝末節(jié)的用法就不再細(xì)講了。Directive 在 Vue 中并不是很重要的一塊,大家平時(shí)寫代碼的時(shí)候更多還是寫 Component。
Filter 和 Mixins 看起來(lái)比較簡(jiǎn)單,略過(guò)。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
微信小程序?qū)崙?zhàn)基于vue2實(shí)現(xiàn)瀑布流的代碼實(shí)例
瀑布流,又稱瀑布流式布局,是比較流行的一種網(wǎng)站頁(yè)面布局,視覺(jué)表現(xiàn)為參差不齊的多欄布局,隨著頁(yè)面滾動(dòng)條向下滾動(dòng),這種布局還會(huì)不斷加載數(shù)據(jù)塊并附加至當(dāng)前尾部,這篇文章主要介紹了微信小程序?qū)崙?zhàn),基于vue2實(shí)現(xiàn)瀑布流,需要的朋友可以參考下2022-12-12Element的Message彈窗重復(fù)彈出問(wèn)題解決
本文主要介紹了Element的Message彈窗重復(fù)彈出,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-09-09vue后臺(tái)管理如何配置動(dòng)態(tài)路由菜單
這篇文章主要介紹了vue后臺(tái)管理如何配置動(dòng)態(tài)路由菜單,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-04-04基于cropper.js封裝vue實(shí)現(xiàn)在線圖片裁剪組件功能
這篇文章主要介紹了基于cropper.js封裝vue實(shí)現(xiàn)在線圖片裁剪組件功能,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2018-03-03Vue報(bào)錯(cuò)Module build failed: Error: Node&nb
這篇文章主要介紹了Vue報(bào)錯(cuò)Module build failed: Error: Node Sass version 7.0.1 is incompatible with 4.0.0.解決方案,需要的朋友可以參考下2023-06-06vue使用pdfjs顯示PDF可復(fù)制的實(shí)現(xiàn)方法
這篇文章主要介紹了vue使用pdfjs顯示PDF可復(fù)制的實(shí)現(xiàn)方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-12-12公共Hooks封裝useTableData表格數(shù)據(jù)實(shí)例
這篇文章主要為大家介紹了公共Hooks封裝useTableData表格數(shù)據(jù)實(shí)例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-12-12