日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

Angular.js中使用$watch监听模型变化

發布時間:2024/4/13 编程问答 40 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Angular.js中使用$watch监听模型变化 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

$watch簡單使用

$watch是一個scope函數,用于監聽模型變化,當你的模型部分發生變化時它會通知你。

?

$watch(watchExpression, listener, objectEquality);

每個參數的說明如下:

  • watchExpression:監聽的對象,它可以是一個angular表達式如'name',或函數如function(){return $scope.name}。

  • listener:當watchExpression變化時會被調用的函數或者表達式,它接收3個參數:newValue(新值), oldValue(舊值), scope(作用域的引用)

  • objectEquality:是否深度監聽,如果設置為true,它告訴Angular檢查所監控的對象中每一個屬性的變化.?如果你希望監控數組的個別元素或者對象的屬性而不是一個普通的值,?那么你應該使用它

  • ?

    舉個栗子:

    $scope.name =?'hello';

    var watch =?$scope.$watch('name',function(newValue,oldValue, scope){

    ??????? console.log(newValue);

    ??????? console.log(oldValue);

    });

    $timeout(function(){

    ????????$scope.name =?"world";

    },1000);

    ?

    $watch性能問題

    太多的$watch將會導致性能問題,$watch如果不再使用,我們最好將其釋放掉。

    $watch函數返回一個注銷監聽的函數,如果我們想監控一個屬性,然后在稍后注銷它,可以使用下面的方式:

    var watch =?$scope.$watch('someModel.someProperty', callback);

    //...

    watch();

    ?

    還有2個和$watch相關的函數:

    $watchGroup(watchExpressions, listener);

    $watchCollection(obj, listener);

    ?

    轉載于:https://www.cnblogs.com/yu-709213564/p/6258822.html

    超強干貨來襲 云風專訪:近40年碼齡,通宵達旦的技術人生

    總結

    以上是生活随笔為你收集整理的Angular.js中使用$watch监听模型变化的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。