好书推荐 好书速递 排行榜 读书文摘

Vue.js 3企业级应用开发实战

Vue.js 3企业级应用开发实战
作者:柳伟卫
出版社:电子工业出版社
出版年:2022-01
ISBN:9787121426803
行业:其它
浏览数:9

内容简介

《Vue.js 3企业级应用开发实战》基于Vue.js 3展开,介绍了应用实例、组件、模板、计算属性、监听器、指令、表单、事件、数据绑定、路由、依赖注入、自定义样式、动画、渲染函数、测试、响应式编程等,还介绍了Vue CLI、TypeScript、Animate.css、Mocha、Vue Router、Naive UI、vue-axios等内容。Vue.js 3完全支持TypeScript,使读者可以采用类、面向对象的方式进行编程。在本书的最后会手把手带领读者一起从零开始实现一个完整的企业级“新闻头条”客户端应用。本书技术前瞻、面向实战、实例丰富。

《Vue.js 3企业级应用开发实战》主要面向的读者群体是对Vue.js感兴趣的学生、前端工程师、系统架构师等

......(更多)

作者简介

柳伟卫

网名老卫、waylau

一线互联网公司架构师,CSDN、开源中国、云栖社区等社区技术专家,慕课网讲师。

具有多年软件开发管理及系统架构经验。负责过多个省、国家级分布式系统的设计与研发,参与了多个大型项目微服务架构的技术改造。

长期跃于各大开源社区,为开源社区编写了等近30余本技术教程,广受网友好评。

已出版出本计算机图书。

......(更多)

目录

第1篇 初识Vue.js

第1章 理解Vue.js及产生的背景 /2

1.1 什么是Vue.js /2

1.2 Vue.js产生的背景 /2

1.2.1 Vue.js与jQuery的不同 /2

1.2.2 Vue.js与React、Angular的比较 /3

1.2.3 如何选择Angular、React和Vue.js /4

1.3 如何学习Vue.js /5

1.3.1 前置知识 /5

1.3.2 学习安排 /5

第2章 快速开启第一个Vue.js应用 /6

2.1 开发环境准备 /6

2.1.1 安装Node.js和NPM /6

2.1.2 设置NPM镜像 /7

2.1.3 选择合适的IDE /7

2.1.4 安装Vue CLI /8

2.1.5 检查和调试Vue.js应用的工具——Vue Devtools /8

2.2 创建Vue.js应用“hello-world” /8

2.2.1 利用Vue CLI初始化Vue.js应用“hello-world” /9

2.2.2 运行Vue.js应用“hello-world” /12

2.3 探索Vue.js应用 /13

2.3.1 整体项目结构 /13

2.3.2 项目根目录文件 /14

2.3.3 node_modules目录 /14

2.3.4 public目录 /14

2.3.5 src目录 /15

2.4 在Vue.js应用中使用TypeScript /19

2.4.1 基于“Vue 3 Preview”创建项目 /19

2.4.2 基于“Manually select features”创建项目 /20

2.4.3 TypeScript应用的差异 /22

第2篇 基础

第3章 TypeScript基础 /26

3.1 TypeScript概述 /26

3.1.1 TypeScript与JavaScript、ECMAScript的关系 /26

3.1.2 TypeScript与Vue.js的关系 /27

3.1.3 使用TypeScript的优势 /27

3.1.4 安装TypeScript /28

3.1.5 TypeScript代码的编译及运行 /28

3.2 变量与常量 /29

3.2.1 var、let、const三者的作用域 /29

3.2.2 变量与常量的区别 /29

3.2.3 变量提升 /30

3.3 TypeScript数据类型 /31

3.3.1 基本类型 /31

3.3.2 对象类型 /35

3.3.3 任意类型 /35

3.3.4 联合类型 /37

3.3.5 交集类型 /37

3.4 强大的面向对象体系 /38

3.4.1 类 /38

3.4.2 接口 /43

3.4.3 【实战】演示接口的使用 /43

3.4.4 泛型 /44

3.4.5 【实战】演示泛型的使用 /44

3.4.6 枚举 /45

3.5 TypeScript的命名空间 /46

3.5.1 声明命名空间 /46

3.5.2 【实战】声明命名空间 /46

3.5.3 命名空间体 /47

3.5.4 导入别名声明 /47

3.5.5 【实战】导入别名声明 /48

3.5.6 导出声明 /49

3.5.7 合并声明 /49

3.5.8 【实战】合并声明 /49

3.6 TypeScript 模块 /50

3.6.1 了解模块 /51

3.6.2 【实战】导入声明 /51

3.6.3 【实战】导入Require声明 /52

3.6.4 【实战】导出声明 /52

3.6.5 【实战】导出分配 /52

3.6.6 了解CommonJS模块 /53

3.6.7 了解AMD模式 /54

3.7 装饰器 /55

3.7.1 定义装饰器 /55

3.7.2 了解装饰器的执行时机 /56

3.7.3 认识4类装饰器 /57

第4章 Vue.js应用实例——一切的起点 /63

4.1 创建“应用实例” /63

4.1.1 第一个“应用实例” /63

4.1.2 让“应用实例”执行方法 /64

4.1.3 理解选项对象 /64

4.1.4 理解根组件 /65

4.1.5 理解MVVM模型 /66

4.2 data property与methods /66

4.2.1 理解data property /67

4.2.2 理解data methods /67

4.3 Vue.js的生命周期 /69

4.3.1 生命周期中的钩子函数 /69

4.3.2 生命周期的图示 /70

4.3.3 【实战】生命周期钩子函数的实例 /71

第5章 Vue.js组件——独立的程序单元 /76

5.1 组件的基本概念 /76

5.1.1 【实战】一个最简单的Vue.js组件的实例 /76

5.1.2 什么是组件 /78

5.1.3 【实战】一个子组件的复用实例 /79

5.1.4 Vue.js组件与Web组件的异同点 /80

5.2 组件的交互方式 /80

5.2.1 【实战】通过prop向子组件

传递数据 /80

5.2.2 【实战】监听子组件的事件 /81

5.2.3 【实战】兄弟组件之间的通信 /84

5.2.4 【实战】通过插槽分发内容 /87

5.3 让组件可以动态加载 /90

5.3.1 实现组件动态加载的步骤 /90

5.3.2 【实战】动态组件的实例 /90

5.4 使用<keep-alive>缓存组件 /96

5.4.1 【实战】<keep-alive>的例子 /97

5.4.2 <keep-alive>缓存组件的配置详解 /98

第6章 Vue.js模板——让内容随着模板中

变量的变化而变化 /101

6.1 了解Vue.js的模板 /101

6.2 【实战】在模板中使用插值 /102

6.2.1 文本 /102

6.2.2 原生HTML代码 /103

6.2.3 绑定HTML attribute /104

6.2.4 JavaScript表达式 /104

6.3 【实战】在模板中使用指令 /105

6.3.1 理解指令中的参数 /106

6.3.2 理解指令中的动态参数 /107

6.3.3 理解指令中的修饰符 /108

6.4 【实战】在模板中使用指令的缩写 /108

6.4.1 使用v-bind指令的缩写 /108

6.4.2 使用v-on指令的缩写 /109

6.5 使用模板的一些约定 /109

6.5.1 对动态参数值的约定 /109

6.5.2 对动态参数表达式的约定 /110

6.5.3 对访问全局变量的约定 /110

第7章 Vue.js计算属性与侦听器——处理响应式数据的复杂逻辑 /111

7.1 通过实例理解“计算属性”的必要性 /111

7.2 【实战】一个“计算属性”的实例 /112

7.2.1 声明“计算属性” /112

7.2.2 模拟数据更改 /114

7.3 “计算属性”缓存与方法的关系 /114

7.4 为什么需要侦听器 /115

7.4.1 理解侦听器 /115

7.4.2 【实战】一个侦听器的实例 /116

第8章 Vue.js样式——让应用变得好看 /119

8.1 绑定样式class /119

8.1.1 【实战】在class中绑定对象 /119

8.1.2 【实战】在class中绑定数组 /121

8.1.3 【实战】在组件上使用class /122

8.2 绑定内联样式 /122

8.2.1 【实战】在内联样式中绑定对象 /123

8.2.2 【实战】在内联样式中绑定数组 /124

8.2.3 【实战】在内联样式中绑定多重值 /124

第9章 Vue.js表达式——根据条件来渲染不同的内容 /126

9.1 条件表达式 /126

9.1.1 【实战】v-if指令的实例 /126

9.1.2 【实战】v-else指令的实例 /127

9.1.3 【实战】v-else-if指令的实例 /127

9.1.4 【实战】v-show指令的实例 /128

9.1.5 理解v-if指令与v-show指令的关系 /128

9.2 for循环表达式 /129

9.2.1 【实战】使用v-for指令遍历数组 /129

9.2.2 【实战】使用v-for指令遍历数组设置索引 /131

9.2.3 【实战】使用v-for指令遍历对象的property名称 /132

9.2.4 【实战】数组过滤 /135

9.2.5 【实战】使用值的范围 /136

9.3 v-for指令的不同使用场景 /137

9.3.1 【实战】在<template>中使用v-for指令 /137

9.3.2 【实战】v-for指令与v-if指令一起使用 /138

9.3.3 【实战】在组件上使用v-for指令 /139

第10章 Vue.js事件——通知做事的状态 /142

10.1 什么是事件 /142

10.1.1 【实战】一个简单的监听事件实例 /142

10.1.2 理解事件的处理方法 /143

10.1.3 处理原始的DOM事件 /144

10.1.4 为什么需要在HTML代码中监听事件 /145

10.2 【实战】多事件处理器的实例 /146

10.3 事件修饰符 /147

10.3.1 什么是事件修饰符 /147

10.3.2 按键修饰符 /149

10.3.3 系统修饰符 /149

第11章 Vue.js表单——采集用户输入的

数据 /151

11.1 理解“表单输入绑定” /151

11.2 【实战】“表单输入绑定”的基础

用法 /152

11.2.1 文本 /152

11.2.2 多行文本 /153

11.2.3 复选框 /153

11.2.4 单选按钮 /155

11.2.5 选择框 /156

11.3 【实战】对表单进行值绑定 /157

11.3.1 复选框 /157

11.3.2 单选按钮 /158

11.3.3 选择框 /160

11.4 【实战】表单修饰符的使用 /161

11.4.1 使用.lazy修饰符的实例 /162

11.4.2 使用.number修饰符的实例 /163

11.4.3 使用.trim修饰符的实例 /163

第3篇 进阶

第12章 深入组件 /166

12.1 什么是“组件注册” /166

12.1.1 理解“组件注册” /166

12.1.2 组件命名 /167

12.2 理解全局注册 /169

12.3 【实战】一个局部注册的实例 /170

12.4 【实战】一个模板引用的实例 /171

12.5 深入介绍prop(输入属性) /173

12.5.1 理解prop /173

12.5.2 prop类型 /174

12.5.3 【实战】传递动态prop /175

12.5.4 【实战】传递动态prop数字 /176

12.5.5 【实战】传递动态prop布尔值 /178

12.5.6 【实战】传递动态prop数组 /179

12.5.7 【实战】传递动态prop对象 /181

12.5.8 【实战】传递动态prop对象中的所有property /182

12.5.9 理解单向下行绑定 /185

12.5.10 【实战】prop类型验证 /186

12.6 理解非prop的attribute /189

12.6.1 【实战】attribute继承 /189

12.6.2 【实战】禁用attribute继承 /191

12.6.3 【实战】多个根节点上的attribute继承 /192

12.7 自定义事件 /195

12.7.1 如何给事件命名 /196

12.7.2 【实战】一个自定义事件的实例 /196

12.8 深入介绍插槽 /199

12.8.1 理解插槽内容 /199

12.8.2 了解渲染作用域 /200

12.8.3 【实战】后备内容(默认内容)的实例 /201

12.8.4 【实战】具名插槽(带名字的插槽)的实例 /204

12.8.5 了解具名插槽的缩写 /209

12.9 理解“依赖注入” /210

12.9.1 “依赖注入”的优点 /210

12.9.2 【实战】“依赖注入”的实例 /211

12.10 【实战】异步组件的实例 /215

第13章 深入样式 /217

13.1 过渡与动画的概述 /217

13.1.1 理解过渡与动画 /217

13.1.2 【实战】基于class的动画 /219

13.1.3 【实战】与style绑定的过渡 /222

13.2 考虑性能 /224

13.2.1 避免触发重绘 /224

13.2.2 利用硬件加速 /226

13.3 持续时间(timing) /226

13.3.1 理解timing /226

13.3.2 持续时间的使用原则 /226

13.4 缓慢的运动(easing) /227

13.4.1 理解缓慢的运动 /227

13.4.2 【实战】缓慢的运动的实例 /227

13.5 过渡 /228

13.5.1 理解过渡 /228

13.5.2 过渡class /231

13.5.3 【实战】自定义过渡class /232

13.5.4 同时使用过渡和动画 /233

13.5.5 显性的过渡持续时间 /233

13.6 列表过渡 /234

13.6.1 理解列表过渡 /234

13.6.2 【实战】列表过渡的实例 /234

第14章 组件的复用与组合 /237

14.1 理解混入 /237

14.1.1 【实战】基本的混入实例 /237

14.1.2 【实战】混入时的选项合并 /239

14.2 自定义指令 /240

14.2.1 【实战】自定义指令的实例 /241

14.2.2 了解指令的钩子函数 /242

14.2.3 【实战】指令绑定动态参数 /242

14.2.4 【实战】指令绑定对象

字面量 /243

14.3 理解传入 /244

14.3.1 【实战】传入的基本实例 /245

14.3.2 【实战】<teleport>与组件一起使用的实例 /247

14.3.3 【实战】在同一个目标元素上使用多个传入 /249

第15章 渲染函数 /251

15.1 理解渲染函数 /251

15.1.1 【实战】使用渲染函数render()

的实例 /251

15.1.2 DOM树 /254

15.1.3 虚拟DOM树 /255

15.2 h()函数 /256

15.2.1 h()函数的参数 /256

15.2.2 【实战】使用h()函数生成子代VNode /256

15.2.3 VNode必须唯一 /258

15.3 使用JavaScript代替模板功能 /259

15.3.1 【实战】代替v-if指令和v-for

指令的实例 /259

15.3.2 【实战】代替v-model指令的

实例 /261

15.3.3 【实战】代替v-on指令的

实例 /262

15.3.4 代替插槽 /262

15.4 模板编译 /263

第16章 测试 /264

16.1 测试概述 /264

16.1.1 传统的测试技术所面临的问题 /264

16.1.2 如何破解测试技术面临的问题 /266

16.1.3 测试类型 /267

16.2 单元测试 /269

16.2.1 理解单元测试 /269

16.2.2 单元测试常用框架 /270

16.2.3 【实战】Mocha单元测试的实例 /270

16.3 组件测试 /274

16.3.1 理解组件测试 /274

16.3.2 组件测试常用框架 /274

16.4 端到端测试 /275

16.4.1 理解端到端测试 /275

16.4.2 端到端测试常用框架 /276

第17章 响应式编程——以声明式的方式去适应变化 /277

17.1 响应式概述 /277

17.1.1 什么是响应式 /277

17.1.2 如何追踪变化 /278

17.1.3 了解Proxy对象 /278

17.1.4 了解侦听器实例 /279

17.2 理解Vue.js响应式编程的原理 /279

17.2.1 声明响应式状态 /279

17.2.2 【实战】ref()方法的使用 /280

17.2.3 响应式状态解构 /282

17.2.4 防止更改响应式对象 /283

17.3 理解响应式计算 /283

17.4 响应式侦听 /284

17.4.1 watchEffect()方法与watch()方法的异同点 /285

17.4.2 【实战】使用watchEffect()方法侦听变化 /285

17.4.3 【实战】停止使用watchEffect()方法侦听 /286

17.4.4 【实战】使用watch()方法侦听多个数据源 /288

17.4.5 【实战】使用watch()方法侦听响应式对象 /290

第18章 路由——实现网页之间的跳转 /292

18.1 路由的概念 /292

18.1.1 链接的类型 /292

18.1.2 什么是路由 /293

18.1.3 路由的核心概念 /293

18.1.4 静态路由和动态路由 /293

18.2 【实战】创建静态路由 /293

18.2.1 安装Vue Router库 /294

18.2.2 创建待路由的子组件 /294

18.2.3 创建路由 /295

18.2.4 了解路由参数history的两种模式 /296

18.2.5 使用路由 /296

18.2.6 运行应用 /298

18.3 【实战】创建动态路由 /299

18.3.1 什么是动态路由 /300

18.3.2 初始化应用 /300

18.3.3 创建待路由的子组件 /300

18.3.4 创建路由 /301

18.3.5 使用路由 /302

18.3.6 运行应用 /304

第4篇 项目实战

第19章 创建“新闻头条”客户端 /308

19.1 应用概述 /308

19.2 需求分析 /308

19.2.1 首页的需求分析 /308

19.2.2 新闻详情页面的需求分析 /309

19.3 架构设计 /310

19.3.1 获取访问API的密钥 /311

19.3.2 了解新闻列表API /312

19.3.3 了解新闻详情API /314

19.4 【实战】初始化“新闻头条”

客户端应用 /316

19.4.1 修改HelloWorld.vue子组件 /317

19.4.2 修改App.vue根组件 /317

19.4.3 运行应用 /318

第20章 实现“新闻头条”客户端首页 /319

20.1 首页概述 /319

20.2 需求分析 /320

20.3 架构设计 /320

20.4 【实战】实现“新闻头条”

客户端首页 /321

20.4.1 添加Naive UI /321

20.4.2 创建组件 /322

20.4.3 实现界面原型 /322

20.4.4 查看完整的首页原型效果 /327

第21章 实现“新闻头条”客户端导航栏 /329

21.1 导航栏概述 /329

21.2 导航栏的需求分析 /329

21.3 导航栏的架构设计 /330

21.4 【实战】实现“新闻头条”客户端的分类查询 /330

21.4.1 新建新闻分类服务 /330

21.4.2 解析新闻分类API数据 /330

21.4.3 展示新闻分类 /331

21.5 【实战】实现“新闻头条”客户端的新闻列表 /333

21.5.1 引入HTTP客户端 /333

21.5.2 解析新闻列表API数据 /334

21.5.3 解决跨域问题 /335

21.5.4 固定导航栏 /336

21.6 【实战】实现导航栏与新闻列表组件通信 /338

21.6.1 监听导航栏的单击事件 /338

21.6.2 自定义导航栏的切换事件 /340

21.6.3 处理导航栏的单击事件 /341

21.6.4 运行应用 /344

第22章 实现“新闻头条”客户端的新闻详情页面 /345

22.1 新闻详情页面的概述 /345

22.2 新闻详情页面的需求分析 /345

22.3 新闻详情页面的架构设计 /346

22.4 【实战】实现“新闻头条”客户端的新闻详情页面 /347

22.4.1 创建“新闻头条”客户端的新闻详情组件 /347

22.4.2 修改“新闻头条”客户端的新闻列表组件 /349

22.4.3 配置路由 /349

22.4.4 运行应用 /351

参考文献 /352

......(更多)

读书文摘

......(更多)

猜你喜欢

点击查看