zoukankan      html  css  js  c++  java
  • 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();
    }]);
    
  • 相关阅读:
    c++数据类型
    c++注释
    c++基本语法
    c++环境配置
    c++简介
    9 HTTP和HTTPS
    12 RESTful架构(SOAP,RPC)
    剑指10二进制中1的个数
    第2章 新手必须掌握的Linux命令
    11个炫酷的Linux终端命令大全
  • 原文地址:https://www.cnblogs.com/liubeimeng/p/6840671.html
Copyright © 2011-2022 走看看