理解angular中$rootscope和$scope

不难理解, rootscopejs scope类似于局部变量

 var a=1;
    function fn(a) {
        a=3; //a是函数的参数
    }
    fn(2);
    console.log(a);//1
var tt = 'aa'; 
function test(){ 
alert(tt);   //undifined
var tt = 'dd'; 
alert(tt); //'dd';
} 
test();

js分为如下两个过程:


1.编译过程

在js的编译过程中,只是将变量声明和函数声明加到词法作用域,但是不进行赋值,在函数中声明的变量会添加到函数的局部作用域中

2.执行过程
在js的编译过程中,因为js是单线程的所以从上往下执行。
第一个aleart

alert(tt);   //undefined

因为在js的编译过程中已经将tt添加到函数的词法环境中,所以在执行时先去函数本身的词法作用域中找是否存在变量tt,因为此时还没有执行var tt = ‘dd’; 所以输出undifined。


下面回到正题


$rootScope针对全局的作用域生效

$scope只针对当前的controller作用域生效


js的代码如下:

 var angular=angular.module('myApp',[]);
    angular.controller('fiscontroller',function ($rootScope,$scope) {
        $rootScope.message='global'; //message在全局中有效
        $scope.message1='fiscontroller';
    });
    angular.controller('seccontroller',function ($rootScope,$scope) {
        $scope.message2='seccontroller';
        console.log($rootScope.message);
    })

html视图的代码如下:

<!DOCTYPE html>
<html lang="en" ng-app="myApp">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script type="text/javascript" src="js/angular.js"></script>
</head>
<body>
<div>{{message}}</div>
<div ng-controller="fiscontroller">{{message1}}
<span>{{message}}</span>
</div>
<div ng-controller="seccontroller">{{message2}}
<span>{{message}}</span>
</div>
</body>
</html>
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值