Heim >Web-Frontend >js-Tutorial >Angular CLI-Blueprint-Generierungscode

Angular CLI-Blueprint-Generierungscode

php中世界最好的语言
php中世界最好的语言Original
2018-05-03 14:35:361450Durchsuche

Dieses Mal bringe ich Ihnen den Angular CLI-Blueprint-Generierungscode. Was sind die Vorsichtsmaßnahmen für den Angular CLI-Blueprint-Generierungscode? Das Folgende ist ein praktischer Fall.

In diesem Artikel geht es hauptsächlich um die Generierung von Komponenten, Anweisungen, Diensten, Klassen, Schnittstellen, Enumerationen usw.

ng generic

Das Format dieses Befehls ist ng generic .

Sie können auch den Parameter --dry-run verwenden, um die generierte Datei aufzulisten. Anstatt es tatsächlich zu generieren.

Zum Beispiel:

Wenn Sie die Komponente Person generieren, wird eine Person.component.ts generiert.

Wenn Sie Service-Verkaufsdaten generieren? data.service.ts wird generiert.

ng generic class user-model generiert ein user-model.ts, das die UserModel-Klasse enthält.

ng generic xxx xxx Der Befehl ist immer noch etwas lang. Hier verfügt Angular CLI über integrierte Aliase für den Befehl, zum Beispiel:

ng generic command person,

generic kann durch den Buchstaben g ersetzt werden, und die Komponente in

kann durch den Buchstaben c ersetzt werden. Diese beiden Befehle sind also gleich:

ng generate component person
ng g c person
Hier können Sie hingehen um komponentenbezogene Befehle und Aliase anzuzeigen:

https://

github.com/angular/angular-cli/wiki/generate-component

Möglicherweise häufig verwendete Befehlsparameter sind:

--flat gibt an, ob kein Ordner erstellt werden muss

  1. --inline-template (-it) ob der Die Vorlage sollte in der TS-Datei platziert werden

  2. --inline-style (-is) Ob der Stil in der TS-Datei platziert werden soll.

  3. --spec Ob es notwendig ist, eine Spezifikationsdatei (Testdatei) zu erstellen

  4. --view-encapsulation (-ve) Ansichtskapselungsstrategie (einfach verstanden als die Umfangsstrategie von Stildateien).

  5. --change-detection (-cd) Änderungserkennungsstrategie.

  6. --prefix Legen Sie das Präfix dieser Komponente fest

  7. -- dry-run (-d), druckt die generierte Dateiliste aus, anstatt sie direkt zu generieren

  8. Sehen Sie sich Folgendes an Es ist bequemer, Aliase zu verwenden:

    ng generate component person
    ng generate component person --inline-template --inline-style
    ng g c person
    ng g c person -it -is
    Probieren Sie die folgenden Befehle aus:
Erstellen Sie das Projekt: ng new my-app. Warten Sie, bis npm installiert ist abgeschlossen, bevor Sie fortfahren.

Geben Sie nach dem Erstellen des Projekts das Verzeichnis ein und führen Sie den Befehl aus:

ng g c person -d

Dieser Befehl generiert die oben genannten 4 Dateien und

update

app.module

.ts.

Als nächstes entfernen Sie den Parameter -d und generieren die Datei:

Sie können sehen, dass die Datei app.module.ts aktualisiert wurde.

Versuchen Sie, eine andere Komponente zu generieren , unter Verwendung einiger Parameter Kapselungs- und Änderungserkennungsstrategie anzeigen:

ng g c student -ve Emulated -cd OnPush

Sie können sehen, dass die Parameter wirksam geworden sind.

Über die Seite zur Quellcodeverwaltung Sie können sehen, welche Aktualisierungen diese beiden Befehle an app.module vorgenommen haben:

Deklarieren Sie jeweils die beiden generierten Komponenten.

Dann übergebe ich...

Richtlinie.

ng g d filter-box -d

Dies ist der Dateibericht, die aktuelle Generation unten:

ng g d filter-box

通过vscode的源码管理, 可以看到变化:

directive生成了两个文件和component一样, 也在app.module进行了声明.

看一下目录结构:

生成的directive的结构是没有目录, 也就是flat的.

如果不想生成flat样式的, 想让其拥有自己的文件夹, 那么就是用--flat参数:

ng g d filter-box2 --flat false

这样就有自己的文件夹了.

commit一下.

Service.

ng g s order-data -d

可以看到 这个命令会生成flat结构的service.

然后把-d去掉, 真实生成文件:

ng g s order-data

可以从源码管理看到, 只生成了两个文件, 并没有在app.module里面注册:

当然可以在这里写代码把刚才生成的service注册进去.

但是正确的做法是使用 -m 参数来指定需要注册的module:

ng g s order-data2 -m app

这次生成的order-data2 service就会在app.module.ts里面进行注册了.

然后再commit一下.

Model/Interface/Enum/Pipe.

model:

ng g cl models/user

这个命令会创建models文件夹, 然后在里面创建user这个model:

interface:

ng g i models/animal

enum:

ng g e models/gender

commit一下.

Pipe.

ng g p camel-case

除了生成两个文件之外, 这个命令默认也会更新app.module.

Module.

ng g m login

可以看到module默认是自带文件夹的.

然后我试试添加一个component, 目的是要在login module进行声明:

可以看到我要创建的welcome component默认是在app.module里面进行声明的, 这时候如果想要在login module进行声明, 就要使用 -m 参数:

去掉-d执行生成命令后:

Sie können die Deklaration der Willkommenskomponente dieses Mal im Login-Modul sehen

Ich glaube, Sie haben die Methode gemeistert, nachdem Sie den Fall in diesem Artikel gelesen haben Weitere spannende Dinge, bitte achten Sie auf PHP-Chinesisch. Weitere verwandte Artikel online!

Empfohlene Lektüre:

Detaillierte Erläuterung der Unit-Tests und E2E-Testschritte mit Angular CLI

JS zur Implementierung von Maus- Ausgelöster Floating-Layer-Effekt

Das obige ist der detaillierte Inhalt vonAngular CLI-Blueprint-Generierungscode. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn