深入浅出Vue.js
85成左右新,超高性价比,整体很新;无盘、无增值服务、无配套习题册、套装书需要联系客服核实。
¥
12.66
1.6折
¥
79
八五品
仅1件
作者刘博文
出版社人民邮电出版社
出版时间2019-03
版次1
装帧平装
货号9787115509055
上书时间2024-11-16
商品详情
- 品相描述:八五品
-
85成左右新,超高性价比,整体很新;无盘、无增值服务、无配套习题册、套装书需要联系客服核实。
图书标准信息
-
作者
刘博文
-
出版社
人民邮电出版社
-
出版时间
2019-03
-
版次
1
-
ISBN
9787115509055
-
定价
79.00元
-
装帧
平装
-
开本
其他
-
页数
282页
-
字数
437千字
- 【内容简介】
-
本书从源码层面分析了vue.js。首先,简要介绍了vue.js;然后详细讲解了其核心技术“变化侦测”,这里带领大家从0到1实现一个简单的“变化侦测”系统;接着详细介绍了虚拟dom技术,其中包括虚拟dom的及其patching算;紧接着详细讨论了模板编译技术,其中包括模板解析器的实现、优化器的以及代码生成器的;后详细介绍了其整体架构以及提供给我们使用的各种api的,同时还介绍了生命周期、错误处理、指令系统与模板过滤器等功能的。本书适合前端开发人员阅读。
- 【作者简介】
-
刘博文,网名berwin,95后,从事web前端工作5年,2015年加入360奇舞团,现任360导航事业部前端工程师,负责360导航首页及二级页创新项目等亿级pv站点的设计与优化,推动vue.js成为部门内广泛使用的核心技术栈,独立研发相关开发工具与技术解决方案并使之成功落地。w3c能工作组成员,在web能领域有深入研究。热爱开源,热爱技术,梦想是用技术改变世界。个人github地址:s://github./berwin。
精彩书评:
本书如庖丁解牛般地分析了vue.js的源码,深入框架设计而又用浅显易懂的方式讲解出来,值得所有前端同学一读再读。——何烁,360导航事业部技术负责人了解源码不是必需的,却是必要的。在遇到疑难杂症的时候,它能帮助我们有条不絮地分析问题,而不是靠猜测或是搜索别人的方案去解决问题。本书将vue.js的各个模块及api的讲解得很透彻,深入浅出,由点及面,其内容适合各个层次的前端开发者。我相信如果你认真阅读了这本书的内容,会对vue.js的理解更为深入,解决问题也将变得游刃有余。——染陌,bat前端工程师,剖析vue.js运行机制作者
- 【目录】
-
章 vue.js简介1
1.1 什么是vue.js 1
1.2 vue.js简史 2
第 一篇 变化侦测
第 2章 object的变化侦测 6
2.1 什么是变化侦测 6
2.2 如何追踪变化 7
2.3 如何收集依赖 7
2.4 依赖收集在哪里 8
2.5 依赖是谁 10
2.6 什么是watcher 10
2.7 递归侦测所有key 12
2.8 关于object的问题 13
2.9 结 14
第3章 array的变化侦测 16
3.1 如何追踪变化 16
3.2 17
3.3 使用覆盖array原型 18
3.4 将方挂载到数组的属上 19
3.5 如何收集依赖 21
3.6 依赖列表存在哪儿 22
3.7 收集依赖 23
3.8 在中获取observer实例 24
3.9 向数组的依赖发送通知 25
3.10 侦测数组中元素的变化 26
3.11 侦测新增元素的变化 27
3.11.1 获取新增元素 27
3.11.2 使用observer侦测新增元素 28
3.12 关于array的问题 29
3.13 结 29
第4章 变化侦测相关的api实现 31
4.1 vm.$watch 31
4.1.1 用 31
4.1.2 watch的 32
4.1.3 deep参数的实现 36
4.2 vm.$set 38
4.2.1 用 38
4.2.2 array的处理 39
4.2.3 key已经存在于target中 40
4.2.4 处理新增的属 40
4.3 vm.$delete 41
4.3.1 用 42
4.3.2 实现 42
4.4 结 45
第二篇 虚拟dom
第5章 虚拟dom简介 48
5.1 什么是虚拟dom 48
5.2 为什么要引入虚拟dom 51
5.3 vue.js中的虚拟dom 51
5.4 结 53
第6章 vnode 54
6.1 什么是vnode 54
6.2 vnode的作用 55
6.3 vnode的类型 56
6.3.1 注释节点 57
6.3.2 文本节点 57
6.3.3 克隆节点 57
6.3.4 元素节点 58
6.3.5 组件节点 59
6.3.6 函数式组件 59
6.4 结 59
第7章 patch 60
7.1 patch介绍 60
7.1.1 新增节点 61
7.1.2 删除节点 62
7.1.3 更新节点 63
7.1.4 小结 63
7.2 创建节点 64
7.3 删除节点 67
7.4 更新节点 68
7.4.1 静态节点 68
7.4.2 新虚拟节点有文本属 69
7.4.3 新虚拟节点无文本属 69
7.4.4 小结 70
7.5 更新子节点 72
7.5.1 更新策略 72
7.5.2 优化策略 77
7.5.3 哪些节点是未处理过的 82
7.5.4 小结 83
7.6 结 86
第三篇 模板编译
第8章 模板编译 88
8.1 概念 88
8.2 将模板编译成渲染函数 89
8.2.1 解析器 90
8.2.2 优化器 91
8.2.3 代码生成器 91
8.3 结 92
第9章 解析器 93
9.1 解析器的作用 93
9.2 解析器运行 94
9.3 html解析器 99
9.3.1 运行 100
9.3.2 截取开始标签 101
9.3.3 截取结束标签 107
9.3.4 截取注释 108
9.3.5 截取条件注释 108
9.3.6 截取doctype 109
9.3.7 截取文本 109
9.3.8 纯文本内容元素的处理 112
9.3.9 使用栈维护dom层级 114
9.3.10 整体逻辑 114
9.4 文本解析器 117
9.5 结 121
第 10章 优化器 122
10.1 找出所有静态节点并标记 125
10.2 找出所有静态根节点并标记 127
10.3 结 129
第 11章 代码生成器 130
11.1 通过ast生成代码字符串 131
11.2 代码生成器的 134
11.2.1 元素节点 134
11.2.2 文本节点 136
11.2.3 注释节点 137
11.3 结 137
第四篇 整体流程
第 12章 架构设计与项目结构 140
12.1 结构 140
12.2 架构设计 143
12.3 结 145
第 13章 实例方与全局api的
实现 146
13.1 数据相关的实例方 147
13.2 事件相关的实例方 147
13.2.1 vm.$on 148
13.2.2 vm.$off 149
13.2.3 vm.$once 152
13.2.4 vm.$emit 153
13.3 生命周期相关的实例方 154
13.3.1 vm.$forceupdate 154
13.3.2 vm.$destroy 155
13.3.3 vm.$nexttick 159
13.3.4 vm.$mount 169
13.4 全局api的实现 178
13.4.1 vue.extend 178
13.4.2 vue.nexttick 182
13.4.3 vue.set 183
13.4.4 vue.delete 183
13.4.5 vue.directive 184
13.4.6 vue.filter 185
13.4.7 vue.ponent 186
13.4.8 vue.use 188
13.4.9 vue.min 189
13.4.10 vue.pile 190
13.4.11 vue.version 190
13.5 结 191
第 14章 生命周期 192
14.1 生命周期图示 192
14.1.1 初始化阶段 193
14.1.2 模板编译阶段 194
14.1.3 挂载阶段 194
14.1.4 卸载阶段 194
14.1.5 小结 194
14.2 从源码角度了解生命周期 195
14.3 errorcaptured与错误处理 199
14.4 初始化实例属 203
14.5 初始化事件 204
14.6 初始化inject 208
14.6.1 provide/inject的使用方式 208
14.6.2 inject的 210
14.7 初始化状态 215
14.7.1 初始化pro 216
14.7.2 初始化methods 224
14.7.3 初始化data 225
14.7.4 初始化puted 228
14.7.5 初始化watch 238
14.8 初始化provide 241
14.9 结 241
第 15章 指令的奥秘 242
15.1 指令概述 242
15.1.1 v-if指令的概述 243
15.1.2 v-for指令的概述 243
15.1.3 v-on指令 244
15.2 自定义指令的 246
15.3 虚拟dom钩子函数 250
15.4 结 251
第 16章 过滤器的奥秘 252
16.1 过滤器概述 253
16.1.1 串联过滤器 254
16.1.2 滤器接收参数 254
16.1.3 resolvefilter的 255
16.2 解析过滤器 256
16.3 结 258
第 17章 很好实践 259
17.1 为列表渲染设置属key 259
17.2 在v-if/v-if-else/v-else中使用key 259
17.3 路由切换组件不变 260
17.3.1 路由导航守卫beforerouteupdate 261
17.3.2 观察 $route对象的变化 261
17.3.3 为router-view组件添加属key 262
17.4 为所有路由统一添加query 262
17.4.1 使用全局守卫beforeeach 263
17.4.2 使用函数劫持 263
17.5 区分vuex与pro的使用边界 264
17.6 避v-if和v-for一起使用 264
17.7 为组件样式设置作用域 266
17.8 避在scoped中使用元素选择器 267
17.9 避隐的父子组件通信 268
17.10 单文件组件如何命名 268
17.10.1 单文件组件的文件名的大小写 268
17.10.2 基础组件名 269
17.10.3 单例组件名 270
17.10.4 紧密耦合的组件名 270
17.10.5 组件名中的单词顺序 271
17.10.6 完整单词的组件名 272
17.10.7 组件名为多个单词 273
17.10.8 模板中的组件名大小写 273
17.10.9 js/jsx中的组件名大小写 274
17.11 自闭合组件 275
17.12 prop名的大小写 276
17.13 多个特的元素 276
17.14 模板中简单的表达式 276
17.15 简单的计算属 277
17.16 指令缩写 278
17.17 良好的代码顺序 278
17.17.1 组件/实例的选项的顺序 278
17.17.2 元素特的顺序 280
17.17.3 单文件组件很好元素的顺序 281
17.18 结 282
点击展开
点击收起
— 没有更多了 —
以下为对购买帮助不大的评价