解耦Angular模块
Decouple Angular modules
我有一个用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
上获取该关键字值。但我认为这使得模块化变得毫无意义,因为它们是耦合在一起的。我还能做什么?
最好的办法是创建一个可以被两个控制器共享,并且可以单独使用的自定义服务,而不是污染父作用域。
相关文章:
- Angular重命名模块后未能实例化模块
- 在Meteor Angular 1.3中使用npm模块
- 如何将Angular 2用于各种网站&使用PHP作为后端的模块
- grunt serve:dist时找不到Angular.js模块,但grunt serve工作正常
- $injector:modulerr将自定义模块注入Angular应用程序
- 如何管理不同的 Angular 模块依赖关系
- 如何检查angular是否已经有模块
- 从函数内部、类内部、模块内部访问 Angular 服务
- 将登录验证模块与现有的Angular JS应用程序集成
- 无法实例化Angular js中的模块错误
- Angular模块仅适用于内联javascript
- 使用Angular JS将常量注入其他模块配置
- 无法在 Angular JS 中加载模块
- 在 Angular js 的不同文件中使用多个模块
- 当作为 CommonJS 模块加载时,Angular 是否全局将自己分配给“window.angular”
- 从 Angular 控制器访问不同模块中的角度服务
- Angular JS生成PDF - 任何创建者 - 制造商模块
- AngularJS - $injector:modulerr 模块错误在 angular.js:36.
- 在 Angular 中动态注入依赖模块
- 无法找到模块'angular'