首页 > 编程 > JavaScript > 正文

对angularJs中controller控制器scope父子集作用域的实例讲解

2019-11-19 12:47:03
字体:
来源:转载
供稿:网友

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>

运行结果:

angularJs controller scope

二、继承但不隔离

在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

以上这篇对angularJs中controller控制器scope父子集作用域的实例讲解就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持武林网。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表