Angular.js中控制器之间的传值详解-创新互联
前言
成都创新互联专注于鲁山网站建设服务及定制,我们拥有丰富的企业做网站经验。 热诚为您提供鲁山营销型网站建设,鲁山网站制作、鲁山网页设计、鲁山网站官网定制、小程序开发服务,打造鲁山网络公司原创品牌,更为您提供鲁山网站排名全网营销落地服务。每个controller都会有自己的scope,所有的scope都是属于 $rootScope的子或者子的子...
那么问题就好解决了,通过$rootScope.$broadcast
广播的事件每个controller都能收到事件
另外,我的经验是,尽量不要用event传数据。应该建立一个service来保存数据,并且设置相应getter/setter,具体如下:
每个controller依赖service,call service.setter(...)
统一的service.setter(...)
在改完数据后可以$emit('data-updated')
每个controller里$on('data-updated', function(){ $scope.data = service.getData() })
通过Angular的话可以通过下面四种方法
1、event
这里可以有两种方式,一种是$scope.$emit
,然后通过监听$rootScope的事件获取参数;另一种是$rootScope.$broadcast
,通过监听$scope的事件获取参数。
这两种方法在最新版本的Angular中已经没有性能区别了,主要就是事件发送的方向不同,可以按实际情况选择。
2、service
可以创建一个专用的事件Service,也可以按照业务逻辑切分,将数据存储在相应的Service中,因为已经有人提过了就不赘述了。
3、$rootScope
这个方法可能会比较dirty一点,胜在方便,也就是把数据存在$rootScope中,这样各个子$scope都可以调用,不过需要注意一下生命周期
4、直接使用$scope.$nextSibling及类似的属性
类似的还有$scope.$parent
。这个方法的缺点就更多了,官方不推荐使用任何$开头的属性,既增加了耦合,又需要处理异步的问题,而且scope的顺序也不是固定的。不推荐
另外就是通过本地存储、全局变量或者现代浏览器的postMessage来传递参数了,除非特殊情况,请避免这类方式。
直接建一个service,不要用什么事件,项目一大N多个controller或者N久再去维护会玩死你,service里提供存和取的方法,简单明了,API容易查找和修改,调试也方便无混乱的依赖关系
1、利用作用域的继承方式
由于作用域的继承是基于js的原型继承方式,所以这里分为两种情况,当作用域上面的值为基本类型的时候,修改父作用域上面的值会 影响到子作用域,反之,修改子作用域只会影响子作用域的值,不会影响父作用域上面的值;如果需要父作用域与子作用域共享一个值 的话,就需要用到后面一种,即作用域上的值为对象,任何一方的修改都能影响另一方,这是因为在js中对象都是引用类型。
基本类型
function Sandcrawler($scope) { $scope.location = "Mos Eisley North"; $scope.move = function(newLocation) { $scope.location = newLocation; }}function Droid($scope) { $scope.sell = function(newLocation) { $scope.location = newLocation; }}// htmlLocation: {{location}}
Location: {{location}}
另外有需要云服务器可以了解下创新互联建站www.cdcxhl.com,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。
本文题目:Angular.js中控制器之间的传值详解-创新互联
标题来源:http://pwwzsj.com/article/dsogio.html