前言

这篇主要是教大家如何快速搭建一个 Angular 项目,纯用于学习。

Before Starting

开始前,我们需要知道几个小知识。

1. Angular Compilation

游览器支持的编程语言是 HTML、CSS、JavaScript (JS)。

但为了提升开发体验,前端攻城狮大多数会选择使用 HTML、Scss、TypeScript (TS) 作为主要开发语言。

于是,项目发布前就需要先把 Scss 和 TS 编译成 CSS 和 JS,这项工程一般由 Webpack 或 Vite 这类 bundle 工具在打包环节顺手完成。

Angular 项目也使用 HTML、Scss、TS 作为主要开发语言,所以发布前它也需要编译。

但是!Angular 的编译远远不只是把 Scss 和 TS 编译成 CSS 和 JS 这么简单。

Angular 编译器是专门针对 Angular 项目而设的,它会把 HTML、Scss、TS 通通编译成 JS,没错!HTML 和 Scss 最终都会变成 JS。

所以,我们在写 Angular 代码时,要有一个 mindset:

我们写的代码和最终游览器执行的代码不是一回事。

Angular 可能会为了提升开发体验,提供语法糖,或者直接创造新语法。

Angular 也可能为了提升性能,把原本可读性高的代码,编译成可读性差,但性能优的代码。

总之,要想深入理解 Angular,我们就需要知道它在中间到底搞了什么鬼。

2. Single-page Application (SPA) & Component First

传统网站结构

一个网站 www.example.com

由多个网页(Page)组成

www.example.com 主页

www.example.com/products 产品页

一个网页则由 HTML、CSS、JS 组成。

单页面应用程序(SPA)结构

一个单页面应用程序 www.example.com

只有一个网页 (Page),但它有很多组件。

www.example.com 主组件

www.example.com/products 产品组件

一个组件由 HTML、Scss、TS 组成。

Angular is Single-page Application

Angular 是 Single-page Application,它只有一个 Page。

Angular 是 Component First,万物皆是组件,这也是 Web Components 倡导的。

组件对比 Page 有几个优势:

  1. 组件颗粒度灵活

    组件可以是一个 Page 里的一部分,也可以充当一整个 Page 内容。

  2. 组件可以灵活嵌套

    虽然 Page 也可以通过 iframe 做嵌套,但体验太差了。

创建项目

1. 安装 Node.js 和 Yarn (Angular 目前用的是 Yarn Classic 哦, 相关 Issue – Yarn PnP Support Status

2. 安装 Angular CLI

npm install -g @angular/cli

3. 创建 Angular 项目

ng new get-started --style=scss --skip-tests --routing=false --ssr=false -s -t

ng 是 Angular CLI 的命令头

new 是创建新项目

get-started 是项目名

--style=scss 是选定使用 Scss 作为编写 CSS 的方式, 如果你 prefer 直接写 CSS 也是可以的。

--skip-tests 是不要生成测试代码。(get started 而已,不需要搞测试)

--routing=false 是不要生成路由代码。(get started 而已,不需要搞路由)

--ssr=false 是不要支持 Server-Side Render (get started 而已,不需要搞服务器渲染)

-s 是 --inline-style command 的缩写。by default,组件由 .html、.scss、.ts  三个 files 组成,inline style 表示去除掉 .scss file,把 style 写入 .ts file 里头。(get started 而已,能少则少)

-t 是 --inline-template command 的缩写,它和 inline style 同理,就是去掉 .html file 把 HTML 代码写入 .ts file 里头。(get started 而已,能少则少)

项目结构

大部分都是前端熟悉的 files, 特别要留意的是

angular.json – 它相等于 webpack.config.js,负责设定 development server、build bundle、等等。

index.html、main.ts、styles.scss 是 for Page

app.component.ts 是 for 组件,里面也包含了 inline style 和 inline HTML。

Page 结构

index.html

这里除了 <app-root> 以外, 啥也没有.

没有 <script> 也没有 <link rel="stylesheet">, 这些会在 compile 阶段插入进去.

main.ts

没有什么特别的, 只是一句启动代码,appConfig 我们先忽略.

style.scss

这里负责 Global Style,比如 reset css、base css、等等.

App 组件结构

写了一个简单得 Hello World

即便我不说, 也应该可以看出它的表达方式吧.

p.s. imports:[CommonModule] 不是必须的,有用到 Angular build-in 指令才需要,但由于太 common 了,所以 CLI by default 都会生成。

启动项目

ng serve --open

--open 是自动打开游览器

效果

总结

1. 这篇主要就是教你把 Angular 跑起来。方便之后跟着教程做。

2. Angular 是 Single Page Web Application。

它只有一个 Page(index.html、main.ts、styles.scss)。

其余的都是组件。组件就是一套 HTML、TS、Scss。.

目录

上一篇 Angular 18+ 高级教程 – 初识 Angular

下一篇 Angular 18+ 高级教程 – Angular Compiler (AKA ngc) Quick View

想查看目录,请移步 Angular 18+ 高级教程 – 目录

喜欢请点推荐,若发现教程内容以新版脱节请评论通知我。happy coding

Angular 18+ 高级教程 – Getting Started的更多相关文章

  1. Siki_Unity_2-9_C#高级教程(未完)

    Unity 2-9 C#高级教程 任务1:字符串和正则表达式任务1-1&1-2:字符串类string System.String类(string为别名) 注:string创建的字符串是不可变的 ...

  2. Pandas之:Pandas高级教程以铁达尼号真实数据为例

    Pandas之:Pandas高级教程以铁达尼号真实数据为例 目录 简介 读写文件 DF的选择 选择列数据 选择行数据 同时选择行和列 使用plots作图 使用现有的列创建新的列 进行统计 DF重组 简 ...

  3. ios cocopods 安装使用及高级教程

    CocoaPods简介 每种语言发展到一个阶段,就会出现相应的依赖管理工具,例如Java语言的Maven,nodejs的npm.随着iOS开发者的增多,业界也出现了为iOS程序提供依赖管理的工具,它的 ...

  4. 【读书笔记】.Net并行编程高级教程(二)-- 任务并行

    前面一篇提到例子都是数据并行,但这并不是并行化的唯一形式,在.Net4之前,必须要创建多个线程或者线程池来利用多核技术.现在只需要使用新的Task实例就可以通过更简单的代码解决命令式任务并行问题. 1 ...

  5. 【读书笔记】.Net并行编程高级教程--Parallel

    一直觉得自己对并发了解不够深入,特别是看了<代码整洁之道>觉得自己有必要好好学学并发编程,因为性能也是衡量代码整洁的一大标准.而且在<失控>这本书中也多次提到并发,不管是计算机 ...

  6. 分享25个新鲜出炉的 Photoshop 高级教程

    网络上众多优秀的 Photoshop 实例教程是提高 Photoshop 技能的最佳学习途径.今天,我向大家分享25个新鲜出炉的 Photoshop 高级教程,提高你的设计技巧,制作时尚的图片效果.这 ...

  7. 展讯NAND Flash高级教程【转】

    转自:http://wenku.baidu.com/view/d236e6727fd5360cba1adb9e.html 展讯NAND Flash高级教程

  8. Net并行编程高级教程--Parallel

    Net并行编程高级教程--Parallel 一直觉得自己对并发了解不够深入,特别是看了<代码整洁之道>觉得自己有必要好好学学并发编程,因为性能也是衡量代码整洁的一大标准.而且在<失控 ...

  9. [转帖]tar高级教程:增量备份、定时备份、网络备份

    tar高级教程:增量备份.定时备份.网络备份 作者: lesca 分类: Tutorials, Ubuntu 发布时间: 2012-03-01 11:42 ė浏览 27,065 次 61条评论 一.概 ...

  10. Angular CLI 使用教程指南参考

    Angular CLI 使用教程指南参考 Angular CLI 现在虽然可以正常使用但仍然处于测试阶段. Angular CLI 依赖 Node 4 和 NPM 3 或更高版本. 安装 要安装Ang ...

随机推荐

  1. Windows下git配合Unity要设置autocrlf=false

    Unity的.asset文件的换行符一定是Unix (LF)格式的,哪怕在设置里选了用Windows (CRLF)也没用,这个选项只对创建的C# Script有效. 这些Unix换行文件提交上去没问题 ...

  2. [oeasy]python0078_变量部分总结_variable_summary

    删除变量 回忆上次内容 上次研究了变量的死 有生就有死 原本的死是在程序退出的时候自动执行的 也可以手动给变量执行死刑 del     del(a)之后 dir()就无法在当前作用域(scope)内观 ...

  3. [oeasy]python0024_unix时间戳_epoch_localtime_asctime_PosixTime_unix纪年法

    输出时间回忆上次内容 通过搜索 我们学会 import 导入 time 了 完整写法为 asc_time = time.asctime( time.localtime( time.time())) 内 ...

  4. [oeasy]python0007-调试程序_debug

    ​ 调试程序 回忆上次内容 ​py​​ 的程序是按照顺序执行的 是一行行挨排解释执行的 程序并不是数量越多越好 kpi也在不断演化 ​ 编辑 写的代码越多 出现的bug就越多 什么是bug 如何找bu ...

  5. Odoo 菜单定义和修改学习总结

    odoo菜单定义和修改学习总结 环境 odoo-14.0.post20221212.tar 定义菜单 方式1: <?xml version="1.0"?> <od ...

  6. jfinal实验体会

    这次实验我使用的是vue前端+jfinal后端,出现了非常多的问题,因此也花费了我不少时间.在一开始啃jfinal的文档的时候,我感觉jfinal是一个和springboot非常类似的框架,但是使用中 ...

  7. 题解 CF653F Paper task

    CF653F Paper task 给定一个长度为 \(n\) 和括号串,求本质不同的合法括号串个数.\(n\le 5\times 10^5\). 考虑如果不是求本质不同,可以想到 DP. 设 \(f ...

  8. docker nginx容器的均衡负载

    创建三个docker容器以实现nginx的负载均衡 编写nginx的dockfile [root@docker nginx]# cat Dockerfile FROM nginx RUN echo ' ...

  9. 14、Spring之基于注解的声明式事务

    14.1.概述 14.1.1.编程式事务 事务功能的相关操作全部通过自己编写代码来实现: Connection conn = ...; try { // 开启事务:关闭事务的自动提交 conn.set ...

  10. 【Mybatis】06 Session获取 & 配置参数总结

    会话获取 SqlSessionFactory 最佳的获取方式就是使用Mybatis提供的资源类加载配置文件 调用会话工厂建造者实例的建造方法注入读取流 要注意的是建造者生成了了实例就可以不需要了 这里 ...