Angular 7 Project Setup (Create first app)

Following are the Angular CLI commands to create the first Angular app.

npm install -g @angular/cli  

ng new my-dream-app  

cd my-dream-app  

ng serve

Run the following command to create your first Angular app.

ng new my-first-app  
Angular 7 Project Setup (Create first app)

Navigate to your first app.

cd my-first-app  

Start your server to run app.

ng serve  
Angular 7 Project Setup (Create first app)

Your server is running on localhost:4200. Now, go to the browser and open it.

Angular 7 Project Setup (Create first app)

Now, you need an IDE to edit and run your app’s code. Here, we are using WebStorm.

Open WebStorm and open your app “my-first-app” in the IDE. It will look like this:

Angular 7 Project Setup (Create first app)

Here, go to src folder, you will see app folder there. Expand the app folder.

Angular 7 Project Setup (Create first app)

You will see 5 components there:

  • app.component.css
  • app.component.html
  • app.component.spec.ts
  • app.component.ts
  • app.module.ts

You can see the code within the different components to understand what is going on and which part is responsible for the outlook of the app.

app.component.css

This part is empty because we don’t specify any CSS here.

Angular 7 Project Setup (Create first app)

app.component.html

This is the most important component, the front page of your app. Here, you can change the salutation used before your app’s name. You can also change the content on the front page and their respective links.

Angular 7 Project Setup (Create first app)

Code:

<div style="text-align:center">  

  <h1>  

    Welcome to {{ title }}!  

  </h1>  

  <img width="300" alt="Angular Logo" src="">  

</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</a></h2>  

  </li>  

  <li>  

    <h2><a target="_blank" rel="noopener" href="https://blog.angular.io/">Angular blog</a></h2>  

  </li>  

</ul>

app.component.spec.ts:

This file is used for testing purpose only.

import { TestBed, async } from '@angular/core/testing';  

import { AppComponent } from './app.component';  

  

describe('AppComponent', () => {  

  beforeEach(async(() => {  

    TestBed.configureTestingModule({  

      declarations: [  

        AppComponent  

      ],  

    }).compileComponents();  

  }));  

  

  it('should create the app', () => {  

    const fixture = TestBed.createComponent(AppComponent);  

    const app = fixture.debugElement.componentInstance;  

    expect(app).toBeTruthy();  

  });  

  

  it(`should have as title 'my-first-app'`, () => {  

    const fixture = TestBed.createComponent(AppComponent);  

    const app = fixture.debugElement.componentInstance;  

    expect(app.title).toEqual('my-first-app');  

  });  

  

  it('should render title in a h1 tag', () => {  

    const fixture = TestBed.createComponent(AppComponent);  

    fixture.detectChanges();  

    const compiled = fixture.debugElement.nativeElement;  

    expect(compiled.querySelector('h1').textContent).toContain('Welcome to my-first-app!');  

  });  

});

app.component.ts

You can change the name of your app here. You just have to change the title.

import { Component } from '@angular/core';  

  

@Component({  

  selector: 'app-root',  

  templateUrl: './app.component.html',  

  styleUrls: ['./app.component.css']  

})  

export class AppComponent {  

  title = 'my-first-app';  

}

app.module.ts

import { BrowserModule } from '@angular/platform-browser';  

import { NgModule } from '@angular/core';  

  

import { AppComponent } from './app.component';  

  

@NgModule({  

  declarations: [  

    AppComponent  

  ],  

  imports: [  

    BrowserModule  

  ],  

  providers: [],  

  bootstrap: [AppComponent]  

})  

export class AppModule { }

Comments

Leave a Reply

Your email address will not be published. Required fields are marked *