基于Angular中ng-controller父子级嵌套的相关属性详解
ng-controller是为应用变量添加控制器
成都创新互联是一家集网站建设,长春企业网站建设,长春品牌网站建设,网站定制,长春网站建设报价,网络营销,网络优化,长春网站推广为一体的创新建站企业,帮助传统企业提升企业形象加强企业竞争力。可充分满足这一群体相比中小企业更为丰富、高端、多元的互联网需求。同时我们时刻保持专业、时尚、前沿,时刻以成就客户成长自我,坚持不断学习、思考、沉淀、净化自己,让我们为更多的企业打造出实用型网站。
当有两个控制器father、child且child 在 father内,那child 可以称为子控制器,它将继承父控制器father的scope。child就可以访问到father的scope中的所有函数和变量。
例:
name1:{{ name1 }}name2:{{ name2 }}
情况1:
app.controller("father",function ($scope) { $scope.name1 = "x"; $scope.name2 = "y"; });
页面显示结果:
name1:x name2:y
情况2:
app.controller("child",function ($scope) { $scope.name1 = "a"; $scope.name2 = "b"; });
页面显示结果:
name1: name2:b:
情况3:
app.controller("father",function ($scope) { if($scope.name1){ $scope.name1 += "!"; console.log($scope.name1); } else { $scope.name1 = "@"; console.log($scope.name1); } if($scope.name2){ $scope.name2 += "#"; console.log($scope.name2); } else { $scope.name2 = "$"; console.log($scope.name2); } console.log("father"); }); app.controller("child",function ($scope) { if($scope.name1){ $scope.name1 += "%"; console.log($scope.name1); } else { $scope.name1 = "^"; console.log($scope.name1); } if($scope.name2){ $scope.name2 += "&"; console.log($scope.name2); } else { $scope.name2 = "*"; console.log($scope.name2); } console.log("child"); });
控制台打印结果:
@ $ father @% $& child
页面显示结果:
name1:@ name2:$&
可以看出name1的页面显示结果与控制台打印结果不一致
结论:
父级控制器先执行而子级控制器后执行。父级和子级控制器都可对父级下scope作用域进行访问操作,但当子级控制器尝试处理父级作用域内、子级作用域外的数据则可能会导致父级中的数据变脏。
以上这篇基于Angular中ng-controller父子级嵌套的相关属性详解就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持创新互联。
名称栏目:基于Angular中ng-controller父子级嵌套的相关属性详解
文章源于:http://scyanting.com/article/ghpidi.html