對angularJs中controller控制器scope父子集作用域的實例講解
更新時間:2018年10月08日 10:24:52 作者:泠泠在路上
今天小編就為大家分享一篇對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.js與node.js項目里用cookie校驗賬戶登錄詳解
這篇文章主要介紹了Angular.js與node.js項目里用cookie校驗賬戶登錄的相關資料,文中介紹的非常詳細,需要的朋友可以參考借鑒,下面來一起看看吧。2017-02-02angular6的table組件開發(fā)的實現(xiàn)示例
這篇文章主要介紹了angular6的table組件開發(fā)的實現(xiàn)示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-12-12