Angular7 - Konfiguracja projektu

W tym rozdziale omówimy konfigurację projektu w Angular 7.

Aby rozpocząć konfigurację projektu, upewnij się, że masz zainstalowany nodejs. You can check the version of node in the command line using the command, node –v, jak pokazano poniżej -

Jeśli nie masz wersji, zainstaluj nodejs z ich oficjalnej strony -https://nodejs.org/en/.

Po zainstalowaniu nodejs, npm zostanie również zainstalowany razem z nim. Aby sprawdzić wersję npm, uruchom npm -v w wierszu poleceń, jak pokazano poniżej -

Mamy więc wersję 10 węzła i wersję npm 6.4.1.

Aby zainstalować Angular 7, wejdź na stronę, https://cli.angular.io aby zainstalować Angular CLI.

Zobaczysz następujące polecenia na stronie internetowej -

npm install -g @angular/cli //command to install angular 7
ng new my-dream-app // name of the project
cd my-dream-app
ng serve

Powyższe polecenia pomagają uzyskać konfigurację projektu w Angular 7.

Stworzymy folder o nazwie projectA7 i zainstaluj angular/cli jak pokazano poniżej -

Po zakończeniu instalacji sprawdź szczegóły zainstalowanych pakietów za pomocą polecenia ng version, jak pokazano poniżej -

Podaje wersję dla Angular CLI, wersję maszynopisu i inne pakiety dostępne dla Angular 7.

Skończyliśmy z instalacją Angulara 7, teraz zaczniemy od konfiguracji projektu.

Aby stworzyć projekt w Angular 7, użyjemy następującego polecenia -

ng new projectname

Możesz użyć wybranej nazwy projektu. Uruchommy teraz powyższe polecenie w linii poleceń.

Tutaj używamy nazwy projektu jako angular7-app . Po uruchomieniu polecenia zapyta Cię o routing, jak pokazano poniżej -

Wpisz y, aby dodać routing do konfiguracji projektu.

Następne pytanie dotyczy arkusza stylów -

Dostępne opcje to CSS, Sass, Less i Stylus. Na powyższym zrzucie ekranu strzałka jest na CSS. Aby zmienić, możesz użyć klawiszy strzałek, aby wybrać ten wymagany do konfiguracji projektu. Obecnie omówimy CSS dla naszego projektu.

Projekt angular7-app został pomyślnie utworzony. Instaluje wszystkie wymagane pakiety niezbędne do uruchomienia naszego projektu w Angular7. Przejdźmy teraz do utworzonego projektu, który znajduje się w kataloguangular7-app.

Zmień katalog w linii poleceń, używając podanej linii kodu -

cd angular7-app

Będziemy korzystać z Visual Studio Code IDE do pracy z Angular 7, możesz użyć dowolnego IDE, czyli Atom, WebStorm itp.

Aby pobrać Visual Studio Code, przejdź do https://code.visualstudio.com/ i kliknij Pobierz dla Windows.

Kliknij Pobierz dla Windows, aby zainstalować IDE i uruchom instalację, aby rozpocząć korzystanie z IDE.

Poniżej znajduje się redaktor -

Nie rozpoczęliśmy w nim żadnego projektu. Weźmy teraz projekt, który stworzyliśmy za pomocą angular-cli.

Rozważymy angular7-appprojekt. Otwórzmyangular7-app i zobacz, jak wygląda struktura folderów.

Teraz, gdy mamy już strukturę plików dla naszego projektu, skompilujmy nasz projekt za pomocą następującego polecenia -

ng serve

The ng serve command builds the application and starts the web server.

Zobaczysz poniżej, gdy polecenie rozpocznie wykonywanie -

Serwer WWW uruchamia się na porcie 4200. Wpisz adres URL, "http://localhost:4200/"w przeglądarce i zobacz wynik. Po skompilowaniu projektu otrzymasz następujące dane wyjściowe -

Po uruchomieniu adresu URL http://localhost:4200/ w przeglądarce zostaniesz przekierowany na następujący ekran -

Wprowadźmy teraz pewne zmiany, aby wyświetlić następującą zawartość -

“Welcome to Angular 7!”

Dokonaliśmy zmian w plikach - app.component.html i app.component.ts. Więcej na ten temat omówimy w kolejnych rozdziałach.

Dokończmy konfigurację projektu. Jeśli widzisz, użyliśmy portu 4200, który jest domyślnym portem używanym przez angular – cli podczas kompilacji. Możesz zmienić port, jeśli chcesz, używając następującego polecenia -

ng serve --host 0.0.0.0 –port 4205

Angular7-app / folder ma następujące cechy folder structure-

  • e2e/- od końca do końca folderu testowego. Głównie e2e służy do testowania integracji i pomaga zapewnić prawidłowe działanie aplikacji.

  • node_modules/- Zainstalowany pakiet npm to node_modules. Możesz otworzyć folder i zobaczyć dostępne pakiety.

  • src/ - W tym folderze będziemy pracować nad projektem przy użyciu Angular 7.Inside src / you will app / folder utworzony podczas konfiguracji projektu i zawiera wszystkie wymagane pliki wymagane dla projektu.

Angular7-app / folder ma następujące cechy file structure -

  • angular.json - W zasadzie zawiera nazwę projektu, wersję CLI itp.

  • .editorconfig - To jest plik konfiguracyjny dla edytora.

  • .gitignore - Plik .gitignore powinien zostać zapisany w repozytorium, aby udostępnić reguły ignorowania innym użytkownikom, którzy klonują repozytorium.

  • package.json - Plik package.json informuje, które biblioteki zostaną zainstalowane w node_modules po uruchomieniu npm install.

Obecnie, jeśli otworzysz plik package.json w edytorze, otrzymasz do niego dodane moduły -

"@angular/animations": "~7.2.0", 
"@angular/common": "~7.2.0", 
"@angular/compiler": "~7.2.0", 
"@angular/core": "~7.2.0", 
"@angular/forms": "~7.2.0", 
"@angular/platform-browser": "~7.2.0", 
"@angular/platform-browser-dynamic": "~7.2.0", 
"@angular/router": "~7.2.0", 
"core-js": "^2.5.4", 
"rxjs": "~6.3.3", 
"tslib": "^1.9.0", 
"zone.js": "~0.8.26"

Jeśli chcesz dodać więcej bibliotek, możesz dodać je tutaj i uruchomić polecenie npm install.

  • tsconfig.json - Zasadniczo zawiera opcje kompilatora wymagane podczas kompilacji.

  • tslint.json - To jest plik konfiguracyjny z regułami, które należy wziąć pod uwagę podczas kompilacji.

Plik src/ folder to główny folder, który wewnętrznie ma inną strukturę plików.

aplikacja

Zawiera pliki opisane poniżej. Pliki te są domyślnie instalowane przez angular-cli.

app.module.ts

Jeśli otworzysz plik, zobaczysz, że kod zawiera odniesienia do różnych bibliotek, które są importowane. Angular-cli użył następujących domyślnych bibliotek do importu: angular / core, platform-browser.

Same nazwy wyjaśniają użycie bibliotek. Są importowane i zapisywane w zmiennych, takich jak deklaracje, importy, dostawcy i bootstrap.

Możemy zobaczyć app-routing.modulejest również dodawany. Dzieje się tak, ponieważ na początku instalacji wybraliśmy routing. Moduł jest dodawany przez @ angular / cli.

Poniżej przedstawiono strukturę pliku -

import { BrowserModule } from '@angular/platform-browser';
import { NgModule } from '@angular/core';
import { AppRoutingModule } from './app-routing.module';
import { AppComponent } from './app.component';

@NgModule({
   declarations: [
      AppComponent
   ],
   imports: [
      BrowserModule,
      AppRoutingModule
   ],
   providers: [],
   bootstrap: [AppComponent]
})
export class AppModule { }

@NgModule jest importowany z @ angular / core i ma obiekt o następujących właściwościach -

Declarations- W deklaracjach przechowywane są odniesienia do komponentów. Składnik aplikacji jest składnikiem domyślnym, który jest tworzony za każdym razem, gdy inicjowany jest nowy projekt. O tworzeniu nowych komponentów dowiemy się w innej sekcji.

Imports- Spowoduje to zaimportowanie modułów, jak pokazano powyżej. Obecnie BrowserModule jest częścią importu importowanego z @ angular / platform-browser. Dodano również moduł routingu AppRoutingModule.

Providers- Będzie to miało odniesienie do utworzonych usług. Usługa zostanie omówiona w kolejnym rozdziale.

Bootstrap - Zawiera odniesienie do utworzonego domyślnego komponentu, tj. AppComponent.

app.component.css- Możesz tutaj napisać swój plik CSS. W tej chwili dodaliśmy kolor tła do elementu div, jak pokazano poniżej.

Struktura pliku jest następująca -

.divdetails {
   background-color: #ccc; 
}

app.component.html

Kod html będzie dostępny w tym pliku.

Struktura pliku jest następująca -

<!--The content below is only a placeholder and can be replaced.--> 
<div style = "text-align:center">
   <h1>Welcome to {{ title }}!</h1> 
   <img width = "300" alt = "Angular Logo" 
   src = "
   ZXdCb3g9IjAgMCAyNTAgMjUwIj4KICAgIDxwYXRoIGZpbGw9IiNERDAwMzEiIGQ9Ik0xMjUgMzBMMzEuOSA
   2My4ybDE0LjIgMTIzLjFMMTI1IDIzMGw3OC45LTQzLjcgMTQuMi0xMjMuMXoiIC8+CiAgICA8cGF0aCBma
   WxsPSIjQzMwMDJGIiBkPSJNMTI1IDMwdjIyLjItLjFWMjMwbDc4LjktNDMuNyAxNC4yLTEyMy4xTDEyNSA
   zMHoiIC8+CiAgICA8cGF0aCAgZmlsbD0iI0ZGRkZGRiIgZD0iTTEyNSA1Mi4xTDY2LjggMTgyLjZoMjEuN2
   wxMS43LTI5LjJoNDkuNGwxMS43IDI5LjJIMTgzTDEyNSA1Mi4xem0xNyA4My4zaC0zNGwxNy00MC45IDE3I
   DQwLjl6IiAvPgogIDwvc3ZnPg=="7> 
</div> 

<h2>Here are some links to help you start:</h2> 
<ul> 
   <li> 
      <h2><a target = "_blank" rel = "noopener" 
         href = "https://angular.io/tutorial">Tour of Heroes</a>
      </h2>
   </li> 
   <li> 
      <h2><a target = "_blank" rel = "noopener" 
         href = https://angular.io/cli">CLI Documentation</>
      </h2> 
   </li> 
   <li> 
      <h2><a target = "_blank" rel = "noopener" 
         href = "https://blog.angular.io/">Angular blog</a>
      </h2> 
   </li> 
</ul> 
<router-outlet></router-outlet>

To jest domyślny kod HTML aktualnie dostępny podczas tworzenia projektu.

app.component.spec.ts

Są to automatycznie generowane pliki, które zawierają testy jednostkowe dla komponentu źródłowego.

app.component.ts

Klasa komponentu jest zdefiniowana tutaj. Możesz przetworzyć strukturę html w pliku .ts. Przetwarzanie będzie obejmować takie czynności, jak łączenie się z bazą danych, interakcje z innymi komponentami, routing, usługi itp.

Struktura pliku jest następująca -

import { Component } from '@angular/core';
@Component({
   selector: 'app-root',  
   templateUrl: './app.component.html', 
   styleUrls: ['./app.component.css'] 
})
export class AppComponent { 
   title = 'Angular 7';
}

app-routing.module.ts

Ten plik zajmie się routingiem wymaganym dla twojego projektu. Jest powiązany z głównym modułem, czyli app.module.ts.

Struktura pliku jest następująca -

import { NgModule } from '@angular/core'; 
import { Routes, RouterModule } from '@angular/router';

const routes: Routes = [];
@NgModule({ 
   imports: [RouterModule.forRoot(routes)], 
   exports: [RouterModule] 
}) 
export class AppRoutingModule { }

Majątek

Możesz zapisywać swoje obrazy, pliki js w tym folderze.

Środowisko

Ten folder zawiera szczegółowe informacje dotyczące środowiska produkcyjnego lub deweloperskiego. Folder zawiera dwa pliki.

  • environment.prod.ts
  • environment.ts

Oba pliki zawierają szczegółowe informacje o tym, czy plik końcowy powinien zostać skompilowany w środowisku produkcyjnym, czy w środowisku deweloperskim.

Dodatkowa struktura plików angular7-app / folder obejmuje:

favicon.ico

Jest to plik, który zwykle znajduje się w katalogu głównym witryny internetowej.

index.html

To jest plik, który jest wyświetlany w przeglądarce.

<html lang = "en"> 
   <head>
      <meta charset = "utf-8"7gt;
      <title>Angular7App</title> 
      <base href = "/">
      <meta name = "viewport" content = "width=device-width, initial-scale=1"> 
      <link rel = "icon" type = "image/x-icon" href = "favicon.ico"> 
   </head> 
   <body> 
      <app-root></app-root> 
   </body> 
</html>

Ciało ma <app-root></app-root>. To jest selektor, który jest używany wapp.component.ts plik i wyświetli szczegóły z app.component.html plik.

main.ts

main.ts to plik, od którego zaczynamy tworzenie naszego projektu. Rozpoczyna się importem podstawowego modułu, którego potrzebujemy. Obecnie, jeśli widzisz angular / core, angular / platform-browser-dynamic, app.module i environment są importowane domyślnie podczas instalacji angular-cli i konfiguracji projektu.

import { enableProdMode } from '@angular/core';
import { platformBrowserDynamic } from '@angular/platform-browser-dynamic';
import { AppModule } from './app/app.module'; 
import { environment } from './environments/environment';

if (environment.production) { 
   enableProdMode(); 
}
platformBrowserDynamic().bootstrapModule(AppModule).catch(err => console.error(err));

PlatformBrowserDynamic (). BootstrapModule (AppModule) ma odwołanie do modułu nadrzędnego AppModule. W związku z tym, gdy jest wykonywany w przeglądarce, plik nosi nazwę index.html. Index.html odwołuje się wewnętrznie do main.ts, który wywołuje moduł nadrzędny, tj. AppModule, gdy wykonywany jest poniższy kod -

platformBrowserDynamic().bootstrapModule(AppModule).catch(err => console.error(err));

Kiedy AppModule jest wywoływany, wywołuje app.module.ts, który dalej wywołuje AppComponent w oparciu o bootstrap w następujący sposób -

bootstrap: [AppComponent]

W app.component.ts, jest selektor: app-rootktóry jest używany w pliku index.html. Spowoduje to wyświetlenie zawartości obecnej wapp.component.html.

W przeglądarce zostaną wyświetlone następujące informacje -

polyfill.ts

Jest to używane głównie w celu zapewnienia zgodności z poprzednimi wersjami.

style.css

To jest plik stylu wymagany dla projektu.

test.ts

Tutaj będą obsługiwane jednostkowe przypadki testowe do testowania projektu.

tsconfig.app.json

Jest to używane podczas kompilacji, zawiera szczegóły konfiguracji, których należy użyć do uruchomienia aplikacji.

tsconfig.spec.json

Pomaga to zachować szczegóły testów.

typings.d.ts

Służy do zarządzania definicją Typescript.

Ostateczna struktura plików będzie następująca -