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

Angular 是一个一站式框架,用于使用相同的可重用代码创建移动和 Web 应用程序。使用 Angular,您可以将整个应用程序划分为可重用的组件,从而更轻松地维护和重用代码。

在本教程系列中,您将学习如何开始使用 Angular 和 MongoDB 作为后端创建 Web 应用程序。您将使用 Node.js 来运行服务器。

在本教程的整个过程中,您将使用 Angular、Node.js 和 MongoDB 构建一个博客应用程序。

在本教程中,您将了解如何开始设置应用程序并创建 Login 组件。

开始使用

让我们开始安装 Angular CLI

复制代码
npm install -g @angular/cli

安装 Angular CLI 后,创建一个名为 AngularBlogApp 的项目文件夹。

复制代码
mkdir AngularBlogApp
cd AngularBlogApp

从项目文件夹中,使用以下命令创建一个新的 Angular 应用:

复制代码
ng new client

创建 client 应用程序后,导航到项目文件夹并使用节点包管理器 (npm) 安装所需的依赖项。

复制代码
cd client
npm install

使用 npm 启动客户端服务器。

复制代码
npm start

您应该让应用程序在 http://localhost:4200/ 上运行。

设置应用程序

您的 Angular Web 应用程序将有一个根组件。在 src/app 文件夹中创建一个名为 root 的文件夹。创建一个名为 root.component.html 的文件并添加以下 HTML 代码:

复制代码
<h3>
    Root Component
</h3>

添加一个名为 root.component.ts 的文件并添加以下代码:

复制代码
import { Component } from '@angular/core';

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

删除文件 app.component.htmlapp.component.tsapp.component.scssapp.component.spec.tssrc/app 文件夹内只有一个名为 app.module.ts 的文件。

app.module.ts 文件中导入 RootComponent

复制代码
import { RootComponent } from './root/root.component';

RootComponent 包含在 ngModules 中并引导它。

复制代码
@NgModule({
  declarations: [
    RootComponent
  ],
  imports: [
    BrowserModule,
    FormsModule
  ],
  providers: [],
  bootstrap: [RootComponent]
})

保存更改并重新启动服务器。当应用程序加载时,您将显示 RootComponent

您将使用 Angular Router 在我们的博客应用程序中进行路由。因此,在 src/app 文件夹内名为 app.routing.ts 的新文件中导入与路由相关的依赖项。

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

定义路由路径以及组件,如下所示:

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

导出路由以创建包含所有路由提供者的模块。

复制代码
export const ROUTING: ModuleWithProviders = RouterModule.forRoot(AppRoutes);

以下是 app.routing.ts 文件的外观:

复制代码
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);

如上面的代码所示,您尚未创建 LoginComponent。添加它是为了清楚起见。

app.module.ts 文件中导入 ROUTING 类。

复制代码
import { ROUTING } from './app.routing';

将其包含在 NgModule 导入中。

复制代码
imports: [
    BrowserModule,
    ROUTING,
    FormsModule
]

RouterOutlet 放置在 root.component.html 页面中。这是渲染路由组件的地方。

复制代码
<router-outlet></router-outlet>

src/app 文件夹内创建一个名为 login 的文件夹。在 login 文件夹中,创建一个名为 login.component.ts 的文件并添加以下代码:

复制代码
import { Component } from '@angular/core';

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

  constructor() {
      
  }

}

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

复制代码
<h3>
    Login Component
</h3>

保存以上更改并重新启动服务器。根据应用程序加载时定义的路由,将显示 LoginComponent

相关推荐
再学一点就睡5 小时前
前端网络实战手册:15个高频工作场景全解析
前端·网络协议
C_心欲无痕6 小时前
有限状态机在前端中的应用
前端·状态模式
C_心欲无痕6 小时前
前端基于 IntersectionObserver 更流畅的懒加载实现
前端
candyTong6 小时前
深入解析:AI 智能体(Agent)是如何解决问题的?
前端·agent·ai编程
柳杉6 小时前
建议收藏 | 2026年AI工具封神榜:从Sora到混元3D,生产力彻底爆发
前端·人工智能·后端
weixin_462446236 小时前
使用 Puppeteer 设置 Cookies 并实现自动化分页操作:前端实战教程
运维·前端·自动化
CheungChunChiu7 小时前
Linux 内核动态打印机制详解
android·linux·服务器·前端·ubuntu
Irene19917 小时前
Vue 官方推荐:kebab-case(短横线命名法)
javascript·vue.js
GIS之路8 小时前
GDAL 创建矢量图层的两种方式
前端
2501_948195348 小时前
RN for OpenHarmony英雄联盟助手App实战:符文配置实现
javascript·react native·react.js