AngularJS笔记---作用域和控制器

什么是作用域. 什么是控制器, 作用域包含了渲染视图时所需的功能和数据,它是所有视图的唯一源头。可以将作用域理解成试图模型(ViewModel). 作用域之间可以是包含关系也可以是独立关系.可以通过设置不同的ng-Controller来让$scope处于不同的作用域下面.

 一.$rootScope

1.1 $rootScope可以理解成全局变量,一旦赋值对整个module都有效.$rootScpoe不依赖于任何一个controller,  app.run是module被加载时候执行的代码. 可以理解成Silverlight MVVM里面的oninit方法.

<html>
<script src="angular.min.js"></script>
<script type="text/javascript">
    var app = angular.module(‘myapp‘,[]);
    app.run(function($rootScope){
        $rootScope.message="hello frank!";
    });
</script>
<head>
    <div ng-app="myapp">
        <h1>{{ message }}</h1>
    </div>
</head>
<body>
</body>
</html>

1.2 AngularJS会优先获取Controller中$scope添加的值.

代码如下: 分别有三个{message}.  testControl2中在$scope中重新赋予了message值.

<html>
<script src="angular.min.js"></script>
<script type="text/javascript">
    var app = angular.module(‘myapp‘,[]);
    app.run(function($rootScope){
        $rootScope.message="hello frank!";
    });

    app.controller(‘testControl1‘,function(){

    });

    app.controller(‘testControl2‘,function($scope){
         $scope.message = "hello loch!";
    });

</script>
<head>
    <div ng-app="myapp">
        {{ message }}
        <div ng-controller="testControl1">
            {{ message }}
        </div>
        <div ng-controller="testControl2">
            {{ message }}
        </div>
    </div>
</head>
<body>
</body>
</html>

运行结果:  testControl2下的message被修改了.

hello frank!
hello frank!
hello loch! 

  二. 控制器(ng-Controller)

ng-Controller氛围两种情况一种是包含,另一种是独立. 我们暂且叫做 父子关系和兄弟关系吧.

2.1 父子关系

2.1.1 代码如下:ChildController 包含在了ParentController里面, 两个button都对Count字段进行赋值。

<html>
<script src="angular.min.js"></script>
<script type="text/javascript">
    var app = angular.module(‘myapp‘,[]);

    app.controller(‘ParentController‘,function($scope){
        $scope.Count = 1;
        $scope.addParent = function(){
            $scope.Count+=1;
        }
    });

    app.controller(‘ChildController‘,function($scope){         // $scope.Count = 1;
         $scope.addChild = function(){
             $scope.Count+=1;
         }
    });

</script>
<head>
    <div ng-app="myapp">
        <div ng-controller="ParentController">
            <span>{{ Count }}</span>
            <button ng-click="addParent()">ParentClick</button>
            <div ng-controller="ChildController">
                <span> {{Count}} </span>
                <button ng-click="addChild()">ChildClick</button>
            </div>
        </div>
    </div>
</head>
<body>
</body>
</html>

2.1.2 运行结果:(在上面demo中,有一串被注释掉的代码,)

A 代码被注解: 当一开始点击ParentClick的时候两个Count一起增加, 然后点击ChildClick的时候只有ChildDiv的Count在增加,然后再回去点击ParentClick的时候,就只有ParentCount在自增

B.代码没被注解: 两者之间的自增都是独立分开的,互补关联.

2.1.3 总结:

因为在AngularJS中会默认先找当前Controller下的值,找不到再去找父类Controller值,如果还找不到就去找$rootScope的值, 对于A类情况在没点击ChildClick的时候,ChildController还没有设置Count的值,那么对应的{Count}只有先去取ParentController里面的$scope.count的值. 当点击了ChildClick后,ChildController中的$scope.count被创建,然后两个Controller就此开始独立.

2.2 兄弟关系.

运行结果: 两个Controller下的Count独立,自增互不影响.

<html>
<script src="angular.min.js"></script>
<script type="text/javascript">
    var app = angular.module(‘myapp‘,[]);

    app.controller(‘BrotherOne‘,function($scope){
        $scope.Count = 1;
        $scope.addParent = function(){
            $scope.Count+=1;
        }
    });

    app.controller(‘BrotherTwo‘,function($scope){
         $scope.Count = 1;
         $scope.addChild = function(){
             $scope.Count+=1;
         }
    });

</script>
<head>
    <div ng-app="myapp">
        <div ng-controller="BrotherOne">
            <span>{{ Count }}</span>
            <button ng-click="addParent()">ParentClick</button>
        </div>
        <div ng-controller="BrotherTwo">
                <span> {{ Count }} </span>
                <button ng-click="addChild()">ChildClick</button>
        </div>
    </div>
</head>
<body>
</body>
</html>

三. 本篇总结    

A.$rootScope == 全局变量
B.绑定的变量默认先从当前Controller的$scope去取
时间: 2024-10-11 11:52:36

AngularJS笔记---作用域和控制器的相关文章

AngularJS之作用域及控制器(一)

前言 之前有接触过基本的AngularJS,未过多涉及,于是乎本系列我们来着重讲讲AngularJS,对AngularJS中重要的几大内容进行梳理并进行一些小的例子的书写.在之前项目过程中用到过avalon,但是avalon并未被广泛使用也就放弃了,至于孰最轻量,性能更好作为非专业的我就不妄下结论,lz只明白一点,业界最流行什么前端框架,招聘大部分要求会哪些框架,lz才会去学习,当然其中的乐趣也是油然而生,每一次敲代码的过程好似在浩瀚大海中探幽一番,别有一番滋味. 简短介绍 AngularJS也

作用域和控制器

AngularJS笔记---作用域和控制器 什么是作用域. 什么是控制器, 作用域包含了渲染视图时所需的功能和数据,它是所有视图的唯一源头.可以将作用域理解成试图模型(ViewModel). 作用域之间可以是包含关系也可以是独立关系.可以通过设置不同的ng-Controller来让$scope处于不同的作用域下面.  一.$rootScope 1.1 rootScope可以理解成全局变量,一旦赋值对整个module都有效.rootScpoe不依赖于任何一个controller,  app.run

AngularJS Scope(作用域)

1. AngularJS Scope(作用域) Scope(作用域) 是应用在 HTML (视图) 和 JavaScript (控制器)之间的纽带. Scope 是一个对象,有可用的方法和属性. Scope 可应用在视图和控制器上. 2. 使用Scope:在 AngularJS 创建控制器时,你可以将 $Scope 对象当作一个参数传递 <!DOCTYPE html> <html> <head> <meta charset="UTF-8">

angualrjs学习总结二(作用域、控制器、过滤器)

一:Scope简介 Scope(作用域) 是应用在 HTML (视图) 和 JavaScript (控制器)之间的纽带.Scope 是一个对象,有可用的方法和属性.Scope 可应用在视图和控制器上.举例:<!doctype html><html> <head> <script src="http://apps.bdimg.com/libs/angular.js/1.4.6/angular.min.js"> </script>

黄聪:AngularJS 动态加载控制器实例-ocLoazLazy

一.AngularJS动态加载控制器和视图实例 路由配置关键代码: [javascript] view plain copy print? //二级页面 $stateProvider.state('main', { url: '/:name', /**如果需要动态加载数据和控制器***/ views: { "": { templateUrl: function ($stateParams) { console.info($stateParams); return '/template/

angularJs的作用域和依赖注入

一.angularJs的作用域 <!DOCTYPE HTML> <html ng-app> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"> <title>angular概述</title> <script src="angular.min.js"></scr

AngularJS: 自定义指令与控制器数据交互

<!doctype html> <html> <head> <meta charset="utf-8"> <title>AngularJS自定义指令与控制器数据交互</title> <!-- <script src="http://cdn.bootcss.com/angular.js/1.3.15/angular.js"></script>--> <sc

AngularJS讲义 - 作用域

什么是作用域? Angular中作用域(scope)是模板以及工作的上下文环境,作用域中存放了应用模型和视图相关的回调行为.作用域是层次化结构的与相关联的DOM结构相对应.作用域可以观察表达式以及传播事件.   原文: scope is an object that refers to the application model. It is an execution context for expressions. Scopes are arranged in hierarchical str

springmvc学习笔记(4)-前端控制器

springmvc学习笔记(4)-前端控制器 springmvc学习笔记4-前端控制器 本文通过前端控制器源码分析springmvc执行过程 1.前端控制器接收请求 调用doDispatch方法 protected void doDispatch(HttpServletRequest request, HttpServletResponse response) throws Exception { HttpServletRequest processedRequest = request; Ha