我已经阅读了很多文档,我越来越困惑。我基本上搞不清楚
我看到了很多自定义组件。有时他们使用指令,有时使用服务。它总是以模块开头。有没有人能举例说明这三种类型之间的区别?
发布于 2012-06-27 08:00:43
可以将模块看作是连接许多其他东西的地方,例如指令、服务、常量等。模块可以注入到其他模块中,从而实现更高级别的重用。
当编写一个angular应用程序时,你会有一个顶层模块,这是你的应用程序代码(没有模板)。
服务主要是控制器之间通信的一种方式,但您可以将一个服务注入到另一个服务中。服务通常被用作访问您的数据存储的一种方式,人们会包装angular API,例如ngResource。这种技术非常有用,因为它使得测试(特别是mocking)变得非常容易。您可以使用服务来执行其他操作,如身份验证、日志记录等。
指令用于创建小部件或包装现有的东西,如jquery插件。包装现有的插件可能是一个挑战,你这样做的原因是为了在插件和angular之间建立一个双向数据绑定。如果您不需要双向数据绑定,那么就不需要包装它们。
指令也是进行DOM操作、捕获DOM事件等的地方。你不应该在控制器或服务中做与DOM相关的事情。创建指令可能会变得非常复杂。我建议你先看看API,看看能不能做你想做的事情,或者向Angular的Google Group寻求建议。
发布于 2012-11-21 04:57:49
来自我自己的personal notes (主要是来自文档、谷歌群组帖子等帖子的片段):
模块
服务
指令(下面的一些条目说的基本上是一样的,但我发现有时稍微不同的措辞会有很大帮助)
当模型的状态=教changes
Angular附带了一组内置的指令(例如ng-* stuff),这些指令对构建web应用程序很有用,但您可以添加自己的指令集,以便将HTML转换为声明性领域特定语言(DSL)。例如,Angular主页演示“创建组件”上的和元素。-不明显的内置指令(因为它们不是以“ng”开头的):a,form,input,script,select,textarea。在Angular下,所有这些都比正常情况下做得更多!
HTML允许你“组件化”。指令通常比ng-include更好。例如,当你开始编写大量主要是数据绑定的超文本标记语言时,将超文本标记语言重构为(可重用的) directives.
另请参阅What is an angularjs directive?
在模块中定义和分组角度的东西(依赖注入的东西)。
共享数据并将web服务器交互封装在服务中。
在指令中扩展HTML和DOM操作。
并使控制器尽可能地“薄”。
https://stackoverflow.com/questions/11171778
复制相似问题