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

angular異步驗證防抖踩坑實錄

 更新時間:2019年12月01日 14:53:07   作者:笙歌會停  
這篇文章主要給大家介紹了關于angular異步驗證防抖踩坑的相關資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用angular具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧

前言

本周的一個需求是在一個異步驗證上加上防抖,防抖,以前也接觸過,依稀記得不難,就沒再去看angluar的官方文檔,直接就開始google寫了,然后……一不小心就掉坑里了。

突然沒了效果的驗證功能

在網上一番查詢以后,選了一個最簡單,最符合的實現(xiàn)

一番修改以后我的代碼成了下面這樣

 public oldPasswordValidator(): AsyncValidatorFn {
  return (ctrl: AbstractControl): Promise<ValidationErrors | null> | Observable<ValidationErrors | null> => {
  rerutn ctrl.valueChanges.pipe(
    debounceTime(2000),
    distinctUntilChanged(),
    switchMap(value => this.checkPasswordIsRight(value)),
    map((isRight: boolean) => (isRight ? null : {passwordError: true})),
    catchError(() => null));
  };

但是驗證器并沒有效果,在c層獲取到的始終是null,而在方法中打印結果,卻可以發(fā)現(xiàn),能夠產生正確的結果

但是獲取到的相關錯誤一直是沒有,更讓我感到驚訝的是表單的valid和invalid竟然同時處在了false,他們不是應該互斥嗎?不是反義詞嗎?

FormControl的status

首先還是解決valid與invalid的疑惑吧,查詢官方文檔。

FormControl的status繼承自AbstractControl

AbstractControl是 FormControl、FormGroup 和 FormArray 的基類。它提供了一些所有控件和控件組共有的行為,比如運行驗證器、計算狀態(tài)和重置狀態(tài)。 它還定義了一些所有子類共享的屬性,如 value、valid 和 dirty。不允許直接實例化它。

找到valid

至此,這個疑問解決了,互斥的并不僅僅是valid和invalid,

還有一個檢查進行狀態(tài):pending和禁止disable,驗證一下,果然此時的狀態(tài)是在pending

為何會一直在pending狀態(tài)?

接著查看表單驗證的官方文檔

自定義異步驗證器和同步驗證器很像,只是它們必須返回一個稍后會輸出 null 或“驗證錯誤對象”的承諾(Promise)或可觀察對象,如果是可觀察對象,那么它必須在某個時間點被完成(complete),那時候這個表單就會使用它輸出的最后一個值作為驗證結果。(譯注:HTTP 服務是自動完成的,但是某些自定義的可觀察對象可能需要手動調用 complete 方法)
返回的可觀察對象必須是有限的,也就是說,它必須在某個時間點結束(complete)。要把無盡的可觀察對象轉換成有限的,可以使用 first、last、take 或 takeUntil 等過濾型管道對其進行處理。

結果很明顯了,上面的觀察者對象是通過valueChangs產生的, 被人訂閱后,并不會主動的調用complete()方法,而會不停的發(fā)布新值。下面的例子可以看出來

給他加個first()讓他只返回第一個結果,果然好使了:

first(predicate: function(value: T, index: number, source: Observable<T>): boolean, resultSelector:function(value: T, index: number): R, defaultValue: R): Observable<T | R>
只發(fā)出由源 Observable 所發(fā)出的值中第一個(或第一個滿足條件的值)。

如果你足夠細心

看的太不仔細了,到解決這個問題之前,一直都沒發(fā)現(xiàn)……

一個更簡單的實現(xiàn)方式

驗證的防抖功能實際上并不需要通過上面的方式實現(xiàn),盡管上面也并不困難。

最簡單的防抖方式,在官方文檔已經提供了:

默認情況下,每當表單值變化之后,都會執(zhí)行所有驗證器。對于同步驗證器,沒有什么會顯著影響應用性能的地方。不過,異步驗證器通常會執(zhí)行某種 HTTP 請求來對控件進行驗證。如果在每次按鍵之后都發(fā)出 HTTP 請求會給后端 API 帶來沉重的負擔,應該盡量避免。

我們可以把updateOn屬性從change(默認值)改成submit或blur來推遲表單驗證的更新時機。

 /**
  * 初始化表單
  */
 initForm() {
  this.modifyPasswordForm = this.fb.group({
    oldPassword: [null, [Validators.required], [this.userService.oldPasswordValidator()]],
    newPassword: [null, Validators.required],
    confirmNewPassword: [null, Validators.required]

    // updateOn 作用是在什么時候更新表單數據
    // https://angular.cn/guide/form-validation#note-on-performance
   }, {updateOn: 'blur'},
  );
 }

想了解更多updateOn的內容,可查看這篇文章。

總結

這次的問題可以完全說出在了看文檔不仔細,神奇的是看了幾遍那個StackOverflow上的回答都沒發(fā)現(xiàn)他比我多了一個first(),雖然因此浪費了不少的時間,但收獲也是巨大的,這波不虧。

好了,以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對腳本之家的支持。

相關文章

  • AngularJS+Node.js實現(xiàn)在線聊天室

    AngularJS+Node.js實現(xiàn)在線聊天室

    隨著互聯(lián)網和信息技術的發(fā)展,如何快速構建高效、強大的動態(tài)網站成為很多人研究的熱點。該文將結合AngularJS和Node.js構建一個在線聊天室,體現(xiàn)AngularJs和Node.js整合的優(yōu)點。
    2015-08-08
  • 深入理解AngularJS中的ng-bind-html指令和$sce服務

    深入理解AngularJS中的ng-bind-html指令和$sce服務

    這篇文章給大家詳細介紹了AngularJS中的ng-bind-html指令和$sce服務,對大家學習AngularJS具有一定參考借鑒價值,有需要都可以參考學習。
    2016-09-09
  • Angular處理未可知異常錯誤的方法詳解

    Angular處理未可知異常錯誤的方法詳解

    這篇文章主要給大家介紹了關于Angular如何處理未可知異常錯誤的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-01-01
  • Angular腳手架開發(fā)的實現(xiàn)步驟

    Angular腳手架開發(fā)的實現(xiàn)步驟

    這篇文章主要介紹了Angular腳手架開發(fā)的實現(xiàn)步驟,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-04-04
  • Angular7實現(xiàn)拖放Drag?Drop示例詳解

    Angular7實現(xiàn)拖放Drag?Drop示例詳解

    這篇文章主要介紹了Angular7實現(xiàn)拖放Drag?Drop示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-12-12
  • Angular模板表單校驗方法詳解

    Angular模板表單校驗方法詳解

    這篇文章主要為大家詳細介紹了Angular模板表單校驗方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-08-08
  • 舉例講解AngularJS中的模塊

    舉例講解AngularJS中的模塊

    這篇文章主要介紹了AngularJS中的模塊,文中講到了其應用模塊和控制器模塊的例子,需要的朋友可以參考下
    2015-06-06
  • 深入淺析AngularJS和DataModel

    深入淺析AngularJS和DataModel

    這篇文章主要介紹了深入淺析AngularJS和DataModel 的相關資料,需要的朋友可以參考下
    2016-02-02
  • Angular.js中ng-include用法及多標簽頁面的實現(xiàn)方式詳解

    Angular.js中ng-include用法及多標簽頁面的實現(xiàn)方式詳解

    這篇文章主要給大家介紹了在Angular.js中ng-include用法及多標簽頁面的實現(xiàn)方式的相關資料,文中通過示例代碼介紹的非常詳細,相信對大家具有一定的參考學習價值,需要的朋友們下面隨著小編一起來學習學習吧。
    2017-05-05
  • 解決angular的$http.post()提交數據時后臺接收不到參數值問題的方法

    解決angular的$http.post()提交數據時后臺接收不到參數值問題的方法

    這篇文章為大家分享了解決angular的$http.post()提交數據時后臺接收不到參數值問題的方法,感興趣的小伙伴們可以參考一下
    2015-12-12

最新評論