From 897bd18fbc77006fea6e7e592108430ae521ae1b Mon Sep 17 00:00:00 2001
From: Judy Bogart
Date: Mon, 15 Jul 2019 12:49:14 -0700
Subject: [PATCH] docs: clarify meaning of injectable decorator (#31573)
PR Close #31573
---
aio/content/guide/cheatsheet.md | 3 +--
packages/core/src/di/injectable.ts | 11 ++++++++---
2 files changed, 9 insertions(+), 5 deletions(-)
diff --git a/aio/content/guide/cheatsheet.md b/aio/content/guide/cheatsheet.md
index 577872ab9c..f3e55928d3 100644
--- a/aio/content/guide/cheatsheet.md
+++ b/aio/content/guide/cheatsheet.md
@@ -185,8 +185,7 @@ is available to declarations
of this module.
@Injectable() class MyService() {} |
-Declares that a class has dependencies that should be injected into the constructor when the dependency injector is creating an instance of this class.
-
+ | Declares that a class can be provided and injected by other classes. Without this decorator, the compiler won't generate enough metadata to allow the class to be created properly when it's injected somewhere.
|
diff --git a/packages/core/src/di/injectable.ts b/packages/core/src/di/injectable.ts
index f79906235b..107e2b5bbf 100644
--- a/packages/core/src/di/injectable.ts
+++ b/packages/core/src/di/injectable.ts
@@ -31,15 +31,20 @@ export type InjectableProvider = ValueSansProvider | ExistingSansProvider |
*/
export interface InjectableDecorator {
/**
- * Decorator that marks a class as available to `Injector` for creation.
+ * Decorator that marks a class as available to be
+ * provided and injected as a dependency.
*
* @see [Introduction to Services and DI](guide/architecture-services)
* @see [Dependency Injection Guide](guide/dependency-injection)
*
* @usageNotes
*
- * The following example shows how service classes are properly marked as
- * injectable.
+ * Marking a class with `@Injectable` ensures that the compiler
+ * will generate the necessary metadata to create the class's
+ * dependencies when the class is injected.
+ *
+ * The following example shows how a service class is properly
+ * marked so that a supporting service can be injected upon creation.
*
*