• AngularJS中$apply


    $apply$scope下的特性,传播model的变化。下面的例子两秒之后控制台会显示出已经更新的model, 然而, view 并没有更新。$digest循环不会只运行一次。在当前的一次循环结束后,它会在执行一次循环用来检查是否有model发生了变化。$digest循环会持续知道model不再发生变化。所以不要在监听中使用脏循环。$digest循环最少也会运行两次。

    /***
     * 关于 apply digest
     * 两秒之后控制台会显示出已经更新的model, 然而, view 并没有更新。
     * 原因:我们没有使用 $apply()方法。
     * $digest循环不会只运行一次。在当前的一次循环结束后,它会在执行一次循环用来检查是否有model发生了变化。
     * 这就是脏检查,它用来处理在listener函数被执行时可能引起的model变化。
     * $digest循环会持续知道model不再发生变化。
     * 所以不要在监听中使用脏循环。
     * $digest循环最少也会运行两次。
     */
    app.controller("messageController",["$scope", "$timeout",function ($scope, $timeout) {
        $scope.getMessage  = function () {
            $timeout(function () {
                $scope.$apply(function () {
                    $scope.message = "三秒后见";
                });
                console.log("message:" + $scope.message);
            }, 2000);
        };
        $scope.getMessage();
    }]);
    
  • 相关阅读:
    构造方法
    不死神兔
    类与对象
    成员变量和局部变量的区别
    this关键字的理解
    private关键字理解
    如何设置客户端证书
    有关中文的正则表达式
    Web和证书服务:建立电子商务外部网
    认证服务Web 网页循序渐进指南
  • 原文地址:https://www.cnblogs.com/liubeimeng/p/6840671.html
Copyright © 2020-2023  润新知