当先锋百科网

首页 1 2 3 4 5 6 7

大家都知道 $rootScope 是全局作用域,保存到此作用域的变量,所有该模块的控制器局部作用域下都能访问到,那么问题来了,如果全局作用域的变量名与局部作用域的名称一样,那么该如何区分调用呢???

  方法还是很简单的:调用全局作用的变量,只需要在变量前加 $root 即可。

不过一般为了防止冲突的变量名,全局作用域下的变量名称起的一般都有唯一性,所以调用时可以直接插值 : {{变量名}} 来调用。

<!DOCTYPE html>
<html ng-app='myApp'>
    <head>
        <meta charset='utf-8'>
        <script src='angular.js'></script>
    </head>
    <body>
        <div ng-controller='myCtrl1'>
            <div>myCtrl1 : {{name}}</div>
            <div>myCtrl1 : {{$root.name}}</div>
        </div>
        <div ng-controller='myCtrl2'>
            <div>myCtrl2 : {{name}}</div>
        </div>
        <script>
            var app = angular.module("myApp",[])
            app.controller("myCtrl1",function($scope, $rootScope){
                $scope.name = 'scope';
            })
            app.controller("myCtrl2",function($scope, $rootScope){
                $rootScope.name = 'rootScope';
            })
        </script>
    </body>
</html>

https://www.cnblogs.com/guofan/p/7133570.html