当前位置: 首页 > news >正文

这本vue3编译原理开源电子书,初中级前端竟然都能看懂

前言

众所周知vue提供了很多黑魔法,比如单文件组件(SFC)、指令、宏函数、css scoped等。这些都是vue提供的开箱即用的功能,大家平时用这些黑魔法的时候有没有疑惑过一些疑问呢。

  • 我们每天写的vue代码一般都是写在*.vue文件中,但是浏览器却只认识html、css、js等文件类型,明显是不认识*.vue文件的,我们写的*.vue文件是如何在浏览器中运行的呢?

  • vue提供了很多指令,比如大家常用的v-model语法糖指令,那你知道这个所谓的语法糖指令到底是什么东西吗?

  • 文档上说了宏函数不需要import导入,那运行的时候函数都没地方定义不就报错了吗?

  • 还有css scoped是如何实现样式隔离的呢?

说到这里不得不推荐一本开源电子书:vue3编译原理揭秘。上面这些问题的答案全部都在这本电子书中,更加难能可贵的是这本书通熟易懂到初中级前端都能看懂。这本书的核心思想是通过debug的方式带你搞清楚vue3中的编译黑魔法。

电子书地址: https://vue-compiler.iamouyang.cn/

book

收费吗?

首先回答这个大家最关注的问题,这本vue3编译原理揭秘开源电子书收费吗?

既然都开源了,当然是 免费的,只求你的一个star。GitHub地址: https://github.com/iamouyang21/vue3-compiler 。

并且还有一个配套的vue源码群,群也是不收费的。
wx

看完这本书我能学到什么

vue因为学习曲线平缓,有其他框架使用经验的同学,基本花上半天时间,看一下文档就可以直接上手。

之所以这么好上手是因为vue提供了很多黑魔法,比如单文件组件(SFC)、指令、宏函数、css scoped等。我们只需要按照官方文档的要求来写就可以轻松上手一个vue项目。

也正是因为vue内部封装了太多API,导致很多同学的技术水平一直停留在只会使用API上,也就是常说的“知其然而不知其所以然”。有时遇见一些特别复杂的需求时,以当前的技术水平,想要去实现这些需求就非常困难了。

这本书可以打破你当前的困境:技术水平一直停留在只会使用API上。看完这本书可以让你对vue编译的认知有质的提升,并且由于本书非常详细。详细到debug源码的每一个步骤都写出来了,你完全可以按照本书的步骤自己去debug读源码。所以这本书不光是教你vue编译原理的知识,更多的是教会你如何自己去通过debug的方式读懂源码。

这就完了?

不,看完本书你还可以在面试的时候去装X。

如果你是候选人,当其他候选人还在和面试官聊烂大街的vue响应式原理时,你上来就和其他人不一样,直接聊看着很神秘的vue编译原理,这无疑在面试中可以加不少分的。

如果你是面试官,有时会遇见一些精通vue的候选者。这些候选者有的是“真精通”,有的却是看了一些常见的vue源码文章的“假精通”。这时你就可以用vue编译原理的问题试探出候选者的真实水平。

50k

这本书讲了哪些东西?

本书分为4大章节:

  • 第一章节是教你如何查看源码、以及一个vue文件如何编译成js文件的全流程。

    start

  • 第二章节是带你搞清楚编译时是如何处理template模块的内容,以及最终如何生成render函数。

    template

  • 第三章节是带你搞清楚编译时是如何处理script模块的内容,以及一些常用的宏函数是如何处理的。

    script

  • 第四章节是带你搞清楚编译时是如何处理style模块的内容,以及如何实现css scoped

    style

最后

vue3编译原理揭秘这本电子书完全免费,并且还有一个配套的vue源码群,群也是不收费的。只求你的一个star

GitHub地址: https://github.com/iamouyang21/vue3-compiler

电子书地址: https://vue-compiler.iamouyang.cn/

http://www.lryc.cn/news/411548.html

相关文章:

  • 小白如何安装WNO(小波神经算子),需要安装python3.8,torch,ptwt,pywt等
  • Java HashMap 源码解读笔记(一)--xunznux
  • “等保测评下的数据加密与隐私保护“
  • Oat++ 后端实现跨域
  • Three basic starting points to do AI
  • 等保测评练习卷22
  • Linux用户-普通用户
  • 世界顶级思想家颜廷利:生命的升华,人类与动物的进化之道
  • 团队心脏:项目比赛中激发团队潜力的策略与技巧
  • Qt安卓开发的一些概念
  • 语音交互、AI问答,等你来体验!
  • 深度对比分析python和RPA,为什么会python了,还要用RPA?
  • el-table支持行拖动
  • git拉取项目并切换到某个tag
  • 数据结构之探索“堆”的奥秘
  • 光影漫游者:高科技球形场馆开启沉浸式体验新时代—轻空间
  • 面试题007:static修饰符可以修饰什么,static的重要规则
  • EasyTwin的动画系统已经到了next level?快来一探究竟!
  • 当业务开展遇到阻力,如何开展?
  • 萨科微半导体整流桥
  • STM32的GPIO输入输出方式设置示例
  • SQL插入、更新和删除数据
  • 如何将幻灯片中的图片背景设置为透明
  • 【雅思考试】-- Day2 - 单词
  • .\venv\Scripts\activate : 无法加载文件 E:\,因为在此系统上禁止运行脚本。
  • C++之explicit
  • 基于FPGA的以太网设计(4)----详解PHY的使用(以YT8531为例)
  • 机器学习之心一区级 | Matlab实现SMA-Transformer-LSTM多变量回归预测(黏菌算法优化)
  • idea导入项目根目录缺失解决方法
  • VMware虚拟机下ubuntu配置