初露锋芒 Angular6 入门项目 - 1

简介: 初露锋芒 Angular6 入门项目 - 1



本文目录

  • 一、项目起步
  • 二、编写路由组件
  • 三、编写页面组件
  • 1.编写单一组件
  • 2.模拟数据
  • 3.编写主从组件
  • 四、编写服务
  • 1.为什么需要服务
  • 2.编写服务
  • 五、引入RxJS
  • 1.关于RxJS
  • 2.引入RxJS
  • 3.改造数据获取方式
  • 六、改造组件
  • 1.添加历史记录组件
  • 2.添加和删除历史记录
  • 七、HTTP改造
  • 1.引入HTTP
  • 2.通过HTTP请求数据
  • 3.通过HTTP修改数据
  • 4.通过HTTP增加数据
  • 5.通过HTTP删除数据
  • 6.通过HTTP查找数据
  • 八、结语

这个入门项目是我学习完Angular 英雄指南教程后,自己手写的一个练习项目,一步一步来,最终的项目源码可以这里查看,大佬们请指点啦。

推荐两个Angular学习网站:

  1. Angular 中文网
  2. Angular 修仙之路

还有呢,我没怎么关注到样式,所以样式会有点丑,主要都放在核心逻辑中了。

最终实现:

  • 首页书本列表数据展示
  • 各个页面静态/动态路由跳转
  • 本地模拟数据服务
  • 书本数据的增删改查
  • 父子组件通信
  • 常用指令使用和介绍

后面我将把这个系列的文章,收录到我的【CuteJavaScript】中,里面有整理了ES6/7/8/9知识点重温JS基础系列文章。

那么,快跟我一步步来完成这个入门项目吧。

零、Angular安装

Angular 需要 Node.js8.x10.x 版本。

检查你的Node.js版本,请在终端/控制台窗口中运行 node -v 命令。

要想安装 Node.js,请访问 nodejs.org。

  1. 安装Angular CLI
npm install -g @angular/cli
  1. 常用命令

后续用到会详细介绍这些命令。

  • 启动服务,并打开新窗口
ng serve --open
# --open 可简写 -o
  • 创建新组件
ng generate component books
# generate 可简写 g
  • 创建新服务
ng generate service books
  • 创建路由模块
ng generate module app-routing --flat --module=app
  • 其他

另外Angular CLI还有很多的命令提供,详细可以查阅官方文档 Angular CLI 命令

最后搭建完是这样:

一、项目起步

  1. 创建项目
ng new books
cd books
  1. 创建所需的两个页面组件
ng g component index
ng g component detail

ggenerate的简写。

二、编写路由组件

这里为了项目结构先起来,所以先简单配置一下路由,后面路由会调整,如果遇到什么不懂,可以查看Angular 路由与导航

  1. 安装路由模块
ng g module app-routing --flat --module=app

知识点:

--flat 把这个文件放进了 src/app 中,而不是单独的目录中。

--module=app 告诉 CLI 把它注册到 AppModuleimports 数组中。

  1. 引入路由模块
// app-routing.module.ts  
import { RouterModule, Routes } from '@angular/router';
  1. 导出路由模块的指令

这里需要添加一个 @NgModule.exports 数组,并传入RouterModule,导出 RouterModule 让路由器的相关指令可以在 AppModule 中的组件中使用。

// app-routing.module.ts  
@NgModule({
  imports: [CommonModule],
  declarations: [],
  exports: [RouterModule]
})
  1. 添加定义路由

这里添加路由的时候,记得将所需要指向的组件也引入进来,这里我们需要引入两个页面的组件:

// app-routing.module.ts  
import { IndexComponent } from './index/index.component';
import { DetailComponent } from './detail/detail.component';

然后将我们所需要的路由定义在routes变量中,类型是我们引入的Routes

// app-routing.module.ts  
const routes: Routes = [
  { path: '', redirectTo:'/index', pathMatch:'full' },    // 1
  { path: 'index', component: IndexComponent},            // 2
  { path: 'detail/:id', component: DetailComponent},      // 3 
]

知识点

angular的路由接收两个参数:

  • path:用于匹配浏览器地址栏中 URL 的字符串。
  • component:当导航到此路由时,路由器展示的组件名称。

第1行代码

作为路由系统的默认路由,当所有路由都不匹配的话,就会重定向到这个路由,并展示对应的组件。

第2行代码

正常情况下的路由配置。

第3行代码

配置的是携带参数的路由,在路由/后,用 : 拼接参数名来实现,获取这个参数的值的方法后面会介绍

另外,我们还可以这么传递参数,直接将数据通过路由传入,后面还会介绍:

{ path: 'pathname', component: DemoComponent, data: { title: 'pingan8787' } },
  1. 添加路由监视

配置好路由还不能使用,需要一个监视路由变化的工具,这时候需要把RouterModule添加到 @NgModule.imports 数组中,并用 routes 来配置它。

这里只需要调用imports数组中的 RouterModule.forRoot() 函数就行了,就像这样:

// app-routing.module.ts  
imports: [ RouterModule.forRoot(routes) ],
  1. 添加路由出口

所谓的路由出口,就是路由所对应的组件展示的地方,接下来我们在app.component.html内容中,添加<router-outlet></router-outlet>

<!-- app.component.html -->
<div>
  <h1> 欢迎来到我的个人书屋! </h1>
  <router-outlet></router-outlet>
</div>

这里的<router-outlet></router-outlet>就是我们路由输出的地方,也是组件展示的地方,简单理解就是,它会告诉路由器要在哪里显示路由的视图。

  1. 添加路由链接

所谓的路由链接,就是出发路由跳转事件的地方,比如一个按钮,一张图片等,我们还是在app.component.html中,使用<a routerLink="/path"></a>添加3个按钮:

<!-- app.component.html -->
<div>
  <h1> 欢迎来到我的个人书屋! </h1>
  <a routerLink="">重定向</a> | 
  <a routerLink="/index">打开首页</a> | 
  <a routerLink="/detail/1">打开书本详情</a>
  <router-outlet></router-outlet>
</div>

这边3个按钮的路由,我们将上面定义的3种路由,传入到routerLink参数中,现在就项目就可以实现页面跳转了。

另外,这里还可以传入一个可选参数routerLinkActive="className",表示当这个<a>标签激活的时候显示的样式,值是一个字符串,为样式的类名:

<a routerLink="/index" routerLinkActive="activeClass">打开首页</a> | 
  1. 获取带参数路由的参数

在第7步中,我们点击 打开书本详情 按钮中,在路由中带了参数,这时候我们需要这么来获取这个参数:

  • 先导出模块ActivatedRouteLocation
// detail.component.ts
import { ActivatedRoute } from '@angular/router';
import { Location } from '@angular/common';
  • 再注入到构造函数中,并将值作为私有变量:
// detail.component.ts
export class DetailComponent implements OnInit {
  constructor(
    private route: ActivatedRoute,
    private location: Location
  ) { }
  ngOnInit() {}
}

知识点:

ActivatedRoute 保存该 DetailComponent 实例的路由信息。可以从这个组件获取URL中的路由参数和其他数据。

Location 是一个 Angular 的服务,用来与浏览器打交道。后续会使用它来导航回上一个视图。

  • 提取路由参数:

这里声明getDetail方法,提取路由参数,并ngOnInit生命周期钩子方法在中执行。

// detail.component.ts
ngOnInit() {
    this.getDetail()
}
getDetail(): void{
    const id = +this.route.snapshot.paramMap.get('id');
    console.log(`此课本的id是${id}`)
}

知识点

route.snapshot 是一个路由信息的静态快照,抓取自组件刚刚创建完毕之后。

paramMap 是一个URL中路由所携带的参数值的对象。"id"对应的值就是要获取的书本的 id。

注意

路由参数总会是字符串。这里我们使用 (+) 操作符,将字符串转换成数字。

现在在浏览器上刷新下页面,再点击 打开书本详情 按钮,可以看到控制台输出了此课本的id是1的结果。

到这一步,我们算是把路由配置完成了,接下来可以开始做页面的逻辑了。

本部分内容到这结束


目录
相关文章
|
4月前
1分钟入门angular动画效果animations,敲简单滴哟~~☺
1分钟入门angular动画效果animations,敲简单滴哟~~☺
|
19天前
|
API 开发者 UED
PrimeFaces:JSF的魔法衣橱,解锁UI设计的无限可能!
【8月更文挑战第31天】本文介绍如何结合 JSF(JavaServer Faces)和 PrimeFaces 构建美观且功能强大的现代用户界面。PrimeFaces 提供丰富的 UI 组件库,包括按钮、输入框、数据网格等,支持现代 Web 标准,简化界面开发。文章通过具体示例展示如何使用 `&lt;p:inputText&gt;` 和 `&lt;p:calendar&gt;` 等组件创建用户表单,并用 `&lt;p:dataTable&gt;` 展示数据集合,提升 JSF 应用的易用性和开发效率。
30 0
|
19天前
|
开发者 安全 SQL
JSF安全卫士:打造铜墙铁壁,抵御Web攻击的钢铁防线!
【8月更文挑战第31天】在构建Web应用时,安全性至关重要。JavaServer Faces (JSF)作为流行的Java Web框架,需防范如XSS、CSRF及SQL注入等攻击。本文详细介绍了如何在JSF应用中实施安全措施,包括严格验证用户输入、使用安全编码实践、实施内容安全策略(CSP)及使用CSRF tokens等。通过示例代码和最佳实践,帮助开发者构建更安全的应用,保护用户数据和系统资源。
32 0
|
19天前
|
开发者 C# C++
揭秘:如何轻松驾驭Uno Platform,用C#和XAML打造跨平台神器——一步步打造你的高性能WebAssembly应用!
【8月更文挑战第31天】Uno Platform 是一个跨平台应用程序框架,支持使用 C# 和 XAML 创建多平台应用,包括 Web。通过编译为 WebAssembly,Uno Platform 可实现在 Web 上运行高性能、接近原生体验的应用。本文介绍如何构建高效的 WebAssembly 应用:首先确保安装最新版本的 Visual Studio 或 VS Code 并配置 Uno Platform 开发环境;接着创建新的 Uno Platform 项目;然后通过安装工具链并使用 Uno WebAssembly CLI 编译应用;最后添加示例代码并测试应用。
38 0
|
19天前
|
前端开发 开发者 安全
JSF支付功能大揭秘:探索如何在Java世界中实现安全无缝的在线支付体验
【8月更文挑战第31天】在电子商务和在线交易日益普及的今天,实现在线支付功能已成为许多Web应用的必备需求。JavaServer Faces (JSF) 作为一种流行的Java Web框架,提供了丰富的组件和工具来构建用户界面,包括与支付网关集成以实现在线支付。支付网关是处理信用卡和借记卡支付的系统,在商家和银行之间起到桥梁作用。本文将探讨如何使用JSF与支付网关集成,以及实现在线支付功能时需要考虑的关键点
32 0
|
19天前
|
开发者 前端开发 开发框架
JSF与移动应用,开启全新交互体验!让你的Web应用轻松征服移动设备,让用户爱不释手!
【8月更文挑战第31天】在现代Web应用开发中,移动设备的普及使得构建移动友好的应用变得至关重要。尽管JSF(JavaServer Faces)主要用于Web应用开发,但结合Bootstrap等前端框架,也能实现优秀的移动交互体验。本文探讨如何在JSF应用中实现移动友好性,并通过示例代码展示具体实现方法。使用Bootstrap的响应式布局和组件可以确保JSF页面在移动设备上自适应,并提供友好的表单输入和提交体验。尽管JSF存在组件库较小和学习成本较高等局限性,但合理利用其特性仍能显著提升用户体验。通过不断学习和实践,开发者可以更好地掌握JSF应用的移动友好性,为Web应用开发贡献力量。
30 0
|
19天前
|
存储 前端开发 JavaScript
"Angular与AWS Amplify的神奇之处:如何用云端连接技术让你的项目一鸣惊人?"
【8月更文挑战第31天】在现代软件开发中,云端连接的前端应用已成为主流。本文探讨了Angular与AWS Amplify的结合,展示了如何通过示例代码快速构建云端连接的前端应用。Angular是由Google支持的开源前端框架,而AWS Amplify是AWS提供的云服务,两者结合可以快速构建云端连接的前端应用。文中还分享了一些最佳实践,帮助开发者更高效地使用这两种技术构建高性能的云端连接的前端应用。随着Angular和AWS Amplify生态的不断成熟,它们将在未来的Web开发中扮演更加重要的角色。
30 0
|
4月前
|
C++
【angular】启动项目和路由配置
【angular】启动项目和路由配置
39 1
|
4月前
|
JavaScript UED 开发者
什么是 Angular 项目的 code split?
什么是 Angular 项目的 code split?
|
4月前
设置Open in Terminal快捷键Alt+Shift+Z,方便angular项目的各种命令输入(多任务状态下)
设置Open in Terminal快捷键Alt+Shift+Z,方便angular项目的各种命令输入(多任务状态下)