时间:2021-05-18
1.ctrl1是父级控制器,ctrl2和ctrl3都是ctrl1的子级控制器,
2.父级ctrl1中name值的改变会影响ctrl2和ctrl3中name值的改变,
3.但是ctrl2有自己的name输入传的值,不会影响ctrl1和ctrl3,这就是继承隔离,
4.ctrl3无name赋值就继承父级ctrl1中的name的值。
一、继承隔离的情况
<div ng-app="module"> <div ng-controller="ctrl1"> {{name}}<input type="text" ng-model="name"> <div ng-controller="ctrl2"> {{name}}<input type="text" ng-model="name"> </div> <div ng-controller="ctrl3"> {{name}} </div> </div></div><script> var m = angular.module('module', []); m.controller('ctrl1', ['$scope', function ($scope) { $scope.name = '泠泠在路上' }]); m.controller('ctrl2', ['$scope', function ($scope) { }]); m.controller('ctrl3', ['$scope', function ($scope) { }]);</script>运行结果:
二、继承但不隔离
在ctrl2中改变name的值,既影响自己的值,也影响父级的值。
代码:
<div ng-app="module"> <div ng-controller="ctrl1"> {{data.name}}<input type="text" ng-model="data.name"> <div ng-controller="ctrl2"> {{data.name}}<input type="text" ng-model="data.name"> </div> <div ng-controller="ctrl3"> {{data.name}} </div> </div></div><script> var m = angular.module('module', []); m.controller('ctrl1', ['$scope', function ($scope) { $scope.data={name:'泠泠在路上'} }]); m.controller('ctrl2', ['$scope', function ($scope) { }]); m.controller('ctrl3', ['$scope', function ($scope) { }]);</script>运行结果:
以上这篇对angularJs中controller控制器scope父子集作用域的实例讲解就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
AngularJS控制器controller的详解一、控制器概念控制器在Angualrjs中的作用是增强视图,并且是一个函数,用来向视图的作用域中添加额外的功能
Scope(作用域)是应用在HTML(视图)和JavaScript(控制器)之间的纽带。Scope是一个对象,有可用的方法和属性。Scope可应用在视图和控制器
AngularJSScope(作用域)Scope(作用域)是应用在HTML(视图)和JavaScript(控制器)之间的纽带。Scope是一个对象,有可用的方法
AngularJSng-controller指令AngularJS实例为应用变量添加控制器:FullName:{{firstName+""+lastName}}
AngularJS应用主要依赖于控制器来控制数据在应用程序中的流动。控制器采用ng-controller指令定义。控制器是一个包含属性/属性和JavaScrip