我有一个用AngularJS制作的搜索web应用程序,其中包括两个angular模块:search-keyword-input模块和search-action模块。
第一个search-keyword-input模块具有建议功能、表单验证功能等。search-action模块的功能是请求数据并在表中显示可排序的结果。所以每个模块都有自己的控制器和指令。
问题是:我模块化的原因是,我想要的是可以重用和解耦的模块。但在此应用程序中,search-keyword-input模块中的关键字模型值必须传递给搜索操作模块( search-action模块必须知道使用哪个关键字来执行搜索)。那么我如何在模块之间传递这个值呢?它们如何在没有耦合的情况下通信?
我已经想出了一种添加父控制器和全局$scope值的方法:
<div ng-controller="globalController">
<div ng-controller="keywordController"></div>
<div ng-controller="searchController"></div>
</div>所以search-keyword模块可以在globalController的$scope上设置关键字值,search-action控制器也可以从globalController中获取关键字值。但我认为这使得模块化变得没有意义,因为它们耦合在一起。
发布于 2015-08-18 09:42:01
最好的办法是创建一个可以由两个控制器共享的自定义服务,也可以单独使用,而不是污染父作用域。
https://stackoverflow.com/questions/32062121
复制相似问题