Home > Web Front-end > JS Tutorial > Angular and MongoDB: Building a blogging application with login functionality

Angular and MongoDB: Building a blogging application with login functionality

王林
Release: 2023-08-28 09:41:09
Original
750 people have browsed it

Angular is a one-stop framework for creating mobile and web applications using the same reusable code. With Angular, you can divide your entire application into reusable components, making it easier to maintain and reuse your code.

In this tutorial series, you will learn how to start creating web applications using Angular and MongoDB as the backend. You'll use Node.js to run the server.

Throughout this tutorial, you will build a blogging application using Angular, Node.js, and MongoDB.

In this tutorial, you will learn how to start setting up the application and create the Login component.

start using

Let’s start installing Angular CLI.

npm install -g @angular/cli
Copy after login

After installing Angular CLI, create a project folder named AngularBlogApp.

mkdir AngularBlogApp
cd AngularBlogApp
Copy after login

From the project folder, create a new Angular app using the following command:

ng new client
Copy after login

After creating the client application, navigate to the project folder and install the required dependencies using the Node Package Manager (npm).

cd client
npm install
Copy after login

Use npm to start the client server.

npm start
Copy after login

You should have the application running on http://localhost:4200/.

Settings Application

Your Angular web application will have a root component. Create a folder named root in the src/app folder. Create a file called root.component.html and add the following HTML code:

<h3>
    Root Component
</h3>
Copy after login

Add a file named root.component.ts and add the following code:

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

@Component({
  selector: 'app-root',
  templateUrl: './root.component.html'
})
export class RootComponent {
  
}
Copy after login

Delete files app.component.html, app.component.ts, app.component.scss and app.component.spec. ts. There is only one file named app.module.ts in the src/app folder.

Import RootComponent in the app.module.ts file.

import { RootComponent } from './root/root.component';
Copy after login

Wrap RootComponent in ngModules and bootstrap it.

@NgModule({
  declarations: [
    RootComponent
  ],
  imports: [
    BrowserModule,
    FormsModule
  ],
  providers: [],
  bootstrap: [RootComponent]
})
Copy after login

Save changes and restart the server. When the application loads, you will display RootComponent.

You will use Angular Router for routing in our blog application. Therefore, import routing related dependencies in a new file named app.routing.ts inside the src/app folder.

import { RouterModule, Routes } from '@angular/router';
import { ModuleWithProviders } from '@angular/core/src/metadata/ng_module';
Copy after login

Define routing paths and components as follows:

export const AppRoutes: Routes = [
    { path: '', component: LoginComponent }
];
Copy after login

Export routes to create a module containing all route providers.

export const ROUTING: ModuleWithProviders = RouterModule.forRoot(AppRoutes);
Copy after login

Here is what the app.routing.ts file looks like:

import { RouterModule, Routes } from '@angular/router';
import { ModuleWithProviders } from '@angular/core/src/metadata/ng_module';

import { LoginComponent } from './login/login.component';

export const AppRoutes: Routes = [
    { path: '', component: LoginComponent }
];

export const ROUTING: ModuleWithProviders = RouterModule.forRoot(AppRoutes);
Copy after login

As shown in the code above, you have not created a LoginComponent. It is added for clarity.

Import the ROUTING class in the app.module.ts file.

import { ROUTING } from './app.routing';
Copy after login

Include it in the NgModule import.

imports: [
    BrowserModule,
    ROUTING,
    FormsModule
]
Copy after login

Place RouterOutlet in the root.component.html page. This is where route components are rendered.

<router-outlet></router-outlet>
Copy after login

Create a folder named login inside the src/app folder. In the login folder, create a file named login.component.ts and add the following code:

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

@Component({
  selector: 'app-login',
  templateUrl: './login.component.html'
})
export class LoginComponent {

  constructor() {
      
  }

}
Copy after login

Create a file named login.component.html and add the following code:

<h3>
    Login Component
</h3>
Copy after login

Save the above changes and restart the server. Depending on the route defined when the application loads, LoginComponent will be displayed.

Angular 和 MongoDB:构建具有登录功能的博客应用程序

Create login component

You already laid the foundation for LoginComponent when you set up your application. Let's create a view of LoginComponent using Bootstrap.

Download the bootstrap CSS styles and include them in the assets folder and include the reference in the src/index.html page.

<link rel="stylesheet" type="text/css" href="./assets/bootstrap.min.css">
Copy after login

Place a wrapper around app-root in the index.html page.

<div class="container">
  	<app-root></app-root>
</div>
Copy after login

Add the following HTML to the login.component.html page.

<form class="form-signin">
     <h2 class="form-signin-heading">Please sign in</h2>
     <label for="inputEmail" class="sr-only">Email address</label>
        <input name="email" type="email" id="inputEmail" class="form-control" placeholder="Email address" required autofocus>
        <label for="inputPassword" class="sr-only">Password</label>
        <input name="password"  type="password" id="inputPassword" class="form-control" placeholder="Password" required>
        <div class="checkbox">
          <label>
            <input type="checkbox" value="remember-me"> Remember me
          </label>
        </div>
    <button class="btn btn-lg btn-primary btn-block" type="button">Sign in</button>
</form>
Copy after login

Create a file named login.component.css in the login folder and add the following CSS styles.

.form-signin {
  max-width: 330px;
  padding: 15px;
  margin: 0 auto;
}
.form-signin .form-signin-heading,
.form-signin .checkbox {
  margin-bottom: 10px;
}
.form-signin .checkbox {
  font-weight: 400;
}
.form-signin .form-control {
  position: relative;
  box-sizing: border-box;
  height: auto;
  padding: 10px;
  font-size: 16px;
}
.form-signin .form-control:focus {
  z-index: 2;
}
.form-signin input[type="email"] {
  margin-bottom: -1px;
  border-bottom-right-radius: 0;
  border-bottom-left-radius: 0;
}
.form-signin input[type="password"] {
  margin-bottom: 10px;
  border-top-left-radius: 0;
  border-top-right-radius: 0;
}
Copy after login

修改 @Component 装饰器以包含 CSS 样式。

@Component({
  selector: 'app-login',
  templateUrl: './login.component.html',
  styleUrls: ['./login.component.css']
})
Copy after login

保存上述更改并尝试加载应用程序。您将在登录视图中显示 LoginComponent

Angular 和 MongoDB:构建具有登录功能的博客应用程序

创建登录服务

LoginComponent 需要与数据库交互以查看登录用户是否有效。所以它需要进行 API 调用。您将数据库交互部分保存在名为 login.service.ts 的单独文件中。

创建一个名为 login.service.ts 的文件并添加以下代码:

import { Injectable } from '@angular/core';
import { HttpClient } from '@angular/common/http';

@Injectable()
export class LoginService {

    constructor(private http: HttpClient){

	}
	
	validateLogin(){
		
	}

}
Copy after login

LoginComponent 中导入 LoginService 并将其添加为组件装饰器中的提供程序。

import { LoginService } from './login.service';
Copy after login
@Component({
  selector: 'app-login',
  templateUrl: './login.component.html',
  styleUrls: ['./login.component.css'],
  providers: [ LoginService ]
})
Copy after login

login.service.ts 文件中添加一个名为 validateLogin 的方法,该方法将进行 API 调用。其外观如下:

validateLogin(user: User){
	return this.http.post('/api/user/login',{
		username : user.username,
		password : user.password
	})
}
Copy after login

如上面的代码所示,它返回一个将在 login.component.ts 文件中订阅的可观察对象。以下是 login.service.ts 文件的外观:

import { Injectable } from '@angular/core';
import { HttpClient } from '@angular/common/http';
import { User } from '../models/user.model';

@Injectable()
export class LoginService {

    constructor(private http: HttpClient){

	}
	
	validateLogin(user: User){
		return this.http.post('/api/user/login',{
			username : user.username,
			password : user.password
		})
	}

}
Copy after login

实施用户登录验证

ngModel 指令添加到 login.component.html 中的输入元素。

 <input name="email" [(ngModel)] = "user.username" type="email" id="inputEmail" class="form-control" placeholder="Email address" required autofocus>
 <input name="password" [(ngModel)] = "user.password" type="password" id="inputPassword" class="form-control" placeholder="Password" required>
Copy after login

向登录按钮添加点击事件。

<button class="btn btn-lg btn-primary btn-block" (click)="validateLogin();" type="button">Sign in</button>
Copy after login

以下是修改后的 login.component.html 的外观:


Copy after login

login.component.ts 文件中定义并初始化用户变量。

public user : User;

constructor(private loginService: LoginService) {
  this.user = new User();
}
Copy after login

User 模型已在 src/app/models 文件夹中定义。其外观如下:

export class User {
    constructor(){
		this.username = '';
		this.password = '';
	}
	public username;
	public password;
}
Copy after login

定义一个名为 validateLogin 的方法,该方法将在单击按钮时调用。该方法如下所示:

validateLogin() {
  if(this.user.username && this.user.password) {
  	this.loginService.validateLogin(this.user).subscribe(result => {
    console.log('result is ', result);
  }, error => {
    console.log('error is ', error);
  });
  } else {
  	alert('enter user name and password');
  }
}
Copy after login

当用户名和密码都输入后,validateLogin 方法会订阅 LoginService 方法来验证用户登录。

以下是 login.component.ts 文件的外观:

import { Component } from '@angular/core';
import { LoginService } from './login.service';
import { User } from '../models/user.model';

@Component({
  selector: 'app-login',
  templateUrl: './login.component.html',
  styleUrls: ['./login.component.css'],
  providers: [ LoginService ]
})
export class LoginComponent {

  public user : User;

  constructor(private loginService: LoginService) {
      this.user = new User();
  }

  validateLogin() {
  	if(this.user.username && this.user.password) {
  		this.loginService.validateLogin(this.user).subscribe(result => {
        console.log('result is ', result);
      }, error => {
        console.log('error is ', error);
      });
  	} else {
  		alert('enter user name and password');
  	}
  }

}
Copy after login

总结

在 Angular 博客应用教程系列的这一部分中,您了解了如何开始使用 Angular 创建 Web 应用。您创建了 Angular 应用程序的基本结构,并创建了 LoginComponent ,这将使用户能够验证用户名和密码。

在本教程系列的下一部分中,您将编写用于用户登录验证的 REST API 并创建主页组件。

本教程的源代码可在 GitHub 上获取。

请在下面的评论中告诉我们您的想法和建议。

The above is the detailed content of Angular and MongoDB: Building a blogging application with login functionality. For more information, please follow other related articles on the PHP Chinese website!

source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template