对angularJs中controller控制器scope父子集作用域的实例讲解
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父子集作用域的实例讲解就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
Angular 4 依赖注入学习教程之FactoryProvider的使用(四)
这篇文章主要给大家介绍了关于Angular 4 依赖注入之FactoryProvider使用的相关资料,文中介绍的非常详细,对大家学习或者使用Angular4具有一定的参考学习价值,需要的朋友们下面来一起看看吧。2017-06-06Angular中Lazy Loading懒加载陷阱避坑最佳实践
这篇文章主要为大家介绍了Angular中Lazy Loading懒加载陷阱避坑最佳实践,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪2023-10-10
最新评论