国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

前端框架Vue.js中Directive知識詳解

2019-11-20 09:01:38
字體:
供稿:網(wǎng)友

Directive

看上去雖然和Angular中的定義類似,Directive 都是對DOM功能的一種拓展,但是 Vue 的 Directive 要弱的多。因為 Vue Component 其實本來就會包含對DOM的操作,所以大多數(shù)時候我們寫一個通用組件都是一個Component 而不是一個 Directive,而 在 Angular 我們寫一個通用的組件一般都是一個 Directive 。
所以我說 Vue 的 Directive 相比于 Angular 要弱的多,也可以說純粹的多,他就是對 DOM 功能的一個拓展,而不是為了封裝和DOM相關(guān)的邏輯。有興趣可以通過對比這兩個UI庫就能明白:
 •Vux https://github.com/airyland/vux
 •Angular Bootstrap https://github.com/angular-ui/bootstrap 

對比就會發(fā)現(xiàn),其實在 Vue 中我們封裝一個通用的組件(其實不管是不是通用)都是一個 Component,但是在 Angular 中卻是一個 Directive,因為 Angular 中的 Controller 其實只能創(chuàng)建一個 $scope 作用域。可以簡單的認為在 Vue Directive = Angular Directive + Controller。前面講到過 Vue 很多設(shè)計都和Angular2類似,Vue 中的 Directive 基本可以等價于 Angular2 的 Directive,但是千萬不要和 Angular 中的 Directive 搞混了。

為了避免誤導(dǎo),所以后面不再拿 Angular Directive 作對比了。

生命周期

生命周期分為三步:
 •bind 第一次綁定到DOM元素上的時候觸發(fā)
 •update bind完成之后立刻觸發(fā),以后每當(dāng)參數(shù)更新的時候都會觸發(fā)
 •unbind 解除和DOM元素的綁定時觸發(fā) 

API 簡潔到哭。。。
其中 update 是最重要的,也就是當(dāng) Directive 接收到一個值的更新的時候就會執(zhí)行對應(yīng)的代碼。update函數(shù)接收的參數(shù)就是用戶通過 Attr 傳入的值。

我們下面實現(xiàn)一個簡單的 Directive,它的作用是對 Todo List 輸入的內(nèi)容進行校驗(表單校驗)。Directive 基本結(jié)構(gòu)如下:

Vue.directive("minlength", { bind: function() { }, update: function(value) { }, unbind: function() { }});

 然后,我們需要在用戶輸入的時候進行校驗,這里實現(xiàn)一個簡單的 minlength 校驗,代碼如下:

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 階段的時候就綁定事件,然后根據(jù) update 時候傳入的 minlength 值來進行判斷。

目前看,Directive 應(yīng)該就是為了實現(xiàn)類似的功能存在的,當(dāng)然還有很多細枝末節(jié)的用法就不再細講了。Directive 在 Vue 中并不是很重要的一塊,大家平時寫代碼的時候更多還是寫 Component。

Filter 和 Mixins 看起來比較簡單,略過。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持武林網(wǎng)。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 宁远县| 新龙县| 宣威市| 综艺| 彰化县| 鲁山县| 日土县| 静安区| 台北县| 福贡县| 肥东县| 大丰市| 山东省| 饶阳县| 南澳县| 嘉荫县| 清丰县| 冷水江市| 张家港市| 商洛市| 呼和浩特市| 南康市| 巴林左旗| 乾安县| 东宁县| 嘉兴市| 瑞安市| 西安市| 吉木乃县| 梅州市| 射洪县| 海安县| 崇仁县| 金平| 阿荣旗| 荣成市| 庆元县| 改则县| 江油市| 延安市| 南川市|