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();
    }]);
    
  • 相关阅读:
    字典-字典练习
    元组
    切片
    列表-列表练习
    一个登录小程序
    py定义变量-循环-条件判断
    charles抓包
    接口测试-Http状态码-postman上传文件
    jm解决乱码问题-参数化-数据库操作-文件上传下载
    (二)CRLF注入
  • 原文地址:https://www.cnblogs.com/liubeimeng/p/6840671.html
Copyright © 2011-2022 走看看