导航:首页 > 源码编译 > vue3源码解析书

vue3源码解析书

发布时间:2022-06-29 14:28:53

‘壹’ vue的hook能将同一功能的代码单独抽成1个方法吗

作者 | 零一 责编 | 张红月
rex的作者是谁?Dan,他的全称叫做Dan Abramov,同时他也是React的核心成员之一
为什么我标题说Dan字节一面挂了呢?
因为昨天晚上字节的web infra团队连线了远在国外的Dan,并且提前收集了200多个网友的问题,从中精选了20几个,让Dan来给一一解答,在其中一个问题的回答中,Dan说他从来没用过Vue,hhhhh,所以有小伙伴就说搞了个段子
Q1: 如何看待rex
我不会推荐任何一个库,要看使用场景吧。比如针对数据和缓存的库,就该用对应的库
Q2: 很多开发者认为react的入门很难,有没有什么快速上手的方法
我认为这取决于大家为什么认为React难,可能难点不同,因为你刚学javascript,这是你的入门,那就会觉得React很难。对于其它库例如Vue,你可以运用一些已经封装好的方法,慢慢的使用中你可以学会一些东西。而react你一上手就要编程,这就是难点所在。如果有人觉得入门很难的话,可能就意味着他们不知道怎么去做一个单页的应用程序,可能不是react本身的问题,但他们会认为是react难以理解的问题。可以先把javascript熟悉了,再来用React就很容易了。
Q3: 对于已经开始用react的人,给一些建议避坑
很重要的一点就是你要用Hook的话,我们推荐使用正确的方法把它们引入你的项目当中。对于react来说有两点,一点是可模仿性,新手可以去学别人的库,参考着去学习。另一点就是对于react渲染来说,你可以把它想成是一个计算,你不需要做很多工作,你只需要返回你需要的react UI即可,这很重要
Q4: 现在react更多关注的是函数编程,js却不是这样的
我认为react的确比其它工具更加偏向于函数,但真正喜欢函数编程的开发者会认为react并不是一个函数编程的工具。我们也不会把组件分解成一个个很小很小的函数。React其实是借用了一些函数的理念,并且基于函数,但不完完全全是一个函数编程工具
Q5: 现在前端发展迅速,你是怎么跟上技术发展速度的
我不是这样想的,但有可能是我没有跟紧潮流,可能是每隔几年就有这样的趋势,但很多像现在的新技术跟以前的技术概念其实很相似,这种情况下,我不会被这种新兴的技术惊到,因为他们对我来说没有什么太大的不同,所以这其实就是对老事物一种新的理解,我们围绕一些基本概念做一些开发而已。
Q6: react在未来如何进步呢?
你认为现在存在哪些重大的问题呢?对我来说我会注意到很多问题都是不同的,不同的问题用不同的手段去解决,其中一个问题比如说, 动画领域我们还没有涉足,很多ui框架会针对一些不同的问题提供一些解决方案, 我的感觉是这些领域看起来不一样,但其实都类似,我们可以互相结合。 以后我们可能会有一个组件工具,或者提供更多的功能,这些功能是紧密结合的,这是我们希望的。
Q7: Concurrent mode,从18版本开始最新被放出来的模式,设计时面临的挑战有哪些?
我想说当前还没有被发行出来,所以我们可以去官网看一下blog,上面有关于版本18更多的信息,关于他有什么内容,信息等等。我们现在有相关的工作小组,并且每天从社区邀请50个人左右帮我们一起合作去发行18版本,保证整个生态系统和他发行的版本是一致的,我们在这方面已经有了很多的讨论,大家都可以阅读,评论,获取更多的信息。我们所做出来的一个大的改变就是我们没有mode了,它不叫concurrent mode,而负责的是render的一种机制,他不会有一个延长等待的时间,比如你如果有输入,他也可以同步的处理,其实他是一种同步多线的处理,这也是我们一直想攻克的难关。这才有了我们现在的18 Alpha版本。
Q8: 很多人会将react跟vue做对比,你是怎么看待这两个框架的?
我自己没用过vue的(what???React核心成员之一竟然没有用过Vue,此处@尤大),所以没法做很细节和全面的对比,从设计方法上来说,我们存在一些区别,比如vue直接改变状态,这有一些好处,你可以随心所欲的想写代码就写代码,很多人都很喜欢这样的方式,但对于我们来说,我们会做一些transition,我们方式不一样,所以从技术来说我们有很大的差异,是两种完全不同的方向。vue可能是基于50年的编程的沉淀,对于我们来说基于我们自己的做法,当然他们的做法在技术上来说也是很棒的,vue更多会用一些实用的技术解决实用的问题,比如提供更加便利的动画的解决方案,更便利的模板,但对于react来说,我们不想去做一些我们没有办法充分相信的解决方案,所以我们给出的东西可能没有那么直接便利,比如我们想做动画功能的话,我们并不会去标准化一些存在的东西,我们会有自己对于动画的想法,这跟现在很多框架都是不一样的,vue可以更快的拿到你所想要的,但react我们有更丰富的库,你就可以学会怎么去做这些事,这就像安卓和ios一样,ios其实很多功能都不包括的,但是它可以帮助你可以更好的完成一些事情。
Q9: vue3停止用flow了,react还用flow?
我并不认为这是一个很关键的问题,我认为这主要取决于库本身是怎么写的。他更多的是关注框架本身如何建立的,跟用户没啥关系,它并不会影响用户使用react的过程,我们并不在意这个点,我们并不是不能改变,只是不太值得
Q10: 你对一些新框架有什么看法,他们都没有使用vdom
我并没有多么细致的使用过这些工具,没有什么深度的见解,的确有很多的设计他们是很棒的,而且大家都走的不同的路,可能是完全相反,对于vdom这个词我不太喜欢,大家理解都不太一样,我认为这个跟性能没什么关系,我不太使用这个称呼,因为这使人很困惑,他指的是UI的内存,我们想让他保留下来,因为他能给我们更多的选择。对于一些复杂的功能,我们的解决方式可能会使用UI的不同版本,比如最左边是0%,右边是100%,中间会有一个滚动条,在调整滚动条只需要调整帧就好了,我们如何产生这种帧,就需要很多的ui进行协助,这就需要vdom的协助,这和性能的关系不大。假设我们要看整个app的性能,需要看你每个组件的功能是什么,它可以做什么,看看app背后的代码是什么,而不是单纯对几行的代码做分析和解读。
Q11: 目前用的大多是vue和react,你对于前端来说如何看待五年后的前端领域
我对这个问题的理解是,ui代码有很多不同的方式,比如放在服务器上还是客户端上,如何去整理它,那我觉得在这方面 框架也可以解决所有的问题,我觉得next.js是可以把react相关的观念去简化,所以他有可能会取代目前的功能,如果大家对Server Component 感兴趣的话,你的思考模式是围绕组件进行的,这是可控的,那你也可以做出自主的决定,吧什么样的组件在服务器去运转,不会占用你太长的时间,代码也是一样的,他们会更加的清晰,你就不需要去思考你是在做渲染还是做别的事情,这是一种很不错的优化。
Q12: 对于找工作的同学来说,什么样的科技公司更吸引人?
我觉得你身边的人比较厉害,你能学到很多东西,这是良性的工作环境,可以学习新的知识,而且还需要你的自主性会比较强,不能命令式的工作(其实当时弹幕里全是一个字:钱!)
Q13: 说说你的个人经历,你刚加入Facebook,如何学习react的相关知识的
react代码其实比较复杂,在最开始需要研究代码,去熟悉,主要还是去了解整个的架构,把它了解透彻了没问题了,就Ok了。还会给一些人提供帮助,我会在一些公开的平台上帮助别人解决问题,回答他们的问题,在那段时间阅读了各种人提出的问题,几千条,这是一个非常好的方法帮我熟悉自己所做的东西,帮他们解决问题,也对自己有帮助。
Q14: react核心团队或社区如何维护这么大的code
我们遇到很多有趣的挑战,我并不认为我们的code很大,我们也是在慢慢的学习如何运行这样的项目,我们有超过5000次的测试。react用户只会用来rendering,不会深入到我们库里。如果你去看我们的代码,我们可能会有一个老js和新Js(即源码文件中以.old.js或.new.js为结尾的文件),它们基本上是相同的,我们这么做是为了应对一些有风险的改变,我们没有看到回归,我们就会把新的改变复制到旧的当中,这听起来很奇怪,但效果还不错。
我认为Facebook就像一个测试机器一样,我们会在工作中验证,我们看到了百分之一的回归,评论下降了1%,我们就花了一个月对各个组件做实验区检测,发现了一个bug并解决了。即使当时下降了1%,但是对于Facebook来说是一个很大的损失。
Q15: 作为react用户,我们去看源码,是不是一个好的做法
我并不认为很有必要,因为很难去理解我们的源码,如果你直接去读,你可能会很困惑,因为你不了解底层的框架,有人跟你解释一下可能更好一些。我经常做的一件事,就是用一个debugger去看这些代码不同的去向,比如在chrome performance里看到函数代码的栈,你可以看到每一个函数发生的不同的事情,比如你在升级的时候就可以看到一些新的事件和功能,所以可以从性能这个方面看到这些基本的功能的目的是什么
Q16: 你是如何保持对react的热情的
我本身就很喜欢,react理念跟我对ui代码的想法很一致,我在facebook之前,在初创公司,当时直接用了react,当时不流行,但给我们工作带来了很大的便利,我们还可以清楚地看到各个功能的状态,我们经常问自己想在屏幕上看到的功能是什么,react就能解决当下这个问题
Q17: 如何像你一样优秀,前端好的学习资源分享
我并不确定我有多么优秀,如果你认为优秀可以做一个非常好看的app,那我并不是,所以说我并不是很确定大家想听到什么样的建议。
建议的话,我觉得你可以不用vue或react这样的框架去写一些ui框架,或者做一些小游戏,比如贪吃蛇,这样去促使你去做,即使它有一些复杂度,但能从中吸取一些经验。
Q18: 休闲时间会做什么呢?
偶尔玩玩堡垒之夜,但是也很久没玩游戏了,平时就听听歌、散散步
Q19: 对于中国开发者的建议
我觉得我不太确定一些事,我不知道react在中国多少人在用,在这个社区里,大家可以有不同的选择,非常感谢他们在翻译上做出的工作(此处@印记中文),我不太确定react在未来能否风靡中国,希望大家去多推荐一下react,让更多人了解到,我们将来做出更多的改变。
Q20: 未来是否愿意会在中国的react社区更多得活跃一下
必须滴!
最后辛苦Dan啦,全程一个半小时一直在解答大家的问题,一口水都没喝。而且他回答问题都回答得非常详细,都尽可能地多说一些,所以远不止我记录的那么点文字,真的是很有爱了~ 期待下一次Dan与国内程序员的互动!!!也感谢 Web infra 团队提供的这次机

‘贰’ vue emit 有多个参数该如何写

详细步骤如下:

一、$emit传递一个参数时

子组件:

this.$emit('closeChange',false)。

父组件:

<posilCom @closeChange="closeCom($event)"></posilCom>closeCom(msg) { this.msg = msg;}。

二、$emit传递多个参数时

子组件:

this.$emit('closeChange',false,true)。

父组件:

<posilCom @closeChange="closeCom(arguments)"></posilCom>closeCom(msg)this.msg1 = msg[0]; this.msg2 = msg[1]。




(2)vue3源码解析书扩展阅读:


一、vue emit 3个参数详细描述:

1、子组件的JS

**/define(function(require, exports, mole){var $ = require("lib_cmd/zepto-cmd"),

Vue = require('lib_cmd/vue-cmd'),

main = require("js_cmd/main-cmd"),

var vm= Vue.component('myaddress', {

template: ' <div data-role="data-widget" data-widget="address-editor"

class="address_mask" id="address-editor"></div>' props:["address","ids"],

methods: {created: function () mole.export= vm;/*注册名为“myaddress”的组件 ,从父组件传递过来两个数据"address","ids"*/

2、父组件EJS页面

<%- include ../../header %>

<link href="/css/vd/activity/myAward.css?v=<%= config.version %>" rel="stylesheet" />

<div data-role="container"

class="body <%= pageName %>" id="myAward"><myaddress :address="editAddr"

:ids="ids"></myaddress>

</div><script> seajs.use('js_cmd/vd/activity/myAward-cmd');</script>

<%- include ../../footer %>

/*在定义的组件 “myaddress”中绑定两个父组件的数据 "editAddr" "ids"*/

3、父组件的JS页面

* Created by youchen.ma on 2017/6/21.

*/define(function (require, exports, mole)

var $ = require("lib_cmd/zepto-cmd"),

Vue = require("lib_cmd/vue-cmd"),

main = require("js_cmd/main-cmd"),

Address = require('js_cmd/vd/venue/widget/venueEditAddress-cmd') //引入子组件的JS文件

二、vue emit定义:

主要内容包括数据绑定、指令、表单控制绑定、过滤器、组件、表单验证、服务通信、路由和视图、vue cli、测试开发和调试、源代码分析以及主流的打包和构建工具。内容全面,讲解详细,示例丰富,适合各级开发人员。


‘叁’ vue前端面试题有哪些呢

文章中给你列举了部分的面试题,这些都是公司面试常遇到的,还有需要的还可以自己去查阅一下资料
1、active-class是哪个组件的属性?嵌套路由怎么定义?
答:vue-router模块的router-link组件。
2、怎么定义vue-router的动态路由?怎么获取传过来的动态参数?
答:在router目录下的index.js文件中,对path属性加上/:id。 使用router对象的params.id
3、vue-router有哪几种导航钩子?
答:三种,一种是全局导航钩子:router.beforeEach(to,from,next),作用:跳转前进行判断拦截。第二种:组件内的钩子;第三种:单独路由独享组件
4、scss是什么?安装使用的步骤是?有哪几大特性?
答:预处理css,把css当前函数编写,定义变量,嵌套。 先装css-loader、node-loader、sass-loader等加载器模块,在webpack-base.config.js配置文件中加多一个拓展:extenstion,再加多一个模块:mole里面test、loader
4.1、scss是什么?在vue.cli中的安装使用步骤是?有哪几大特性?
答:css的预编译
使用步骤:
第一步:用npm 下三个loader(sass-loader、css-loader、node-sass)
第二步:在build目录找到webpack.base.config.js,在那个extends属性中加一个拓展.scss
第三步:还是在同一个文件,配置一个mole属性
第四步:然后在组件的style标签加上lang属性 ,例如:lang=”scss”
有哪几大特性:
1、可以用变量,例如($变量名称=值);
2、可以用混合器,例如()
3、可以嵌套
5、mint-ui是什么?怎么使用?说出至少三个组件使用方法?
答:基于vue的前端组件库。npm安装,然后import样式和js,vue.use(mintUi)全局引入。在单个组件局部引入:import {Toast} from ‘mint-ui’。组件一:Toast(‘登录成功’);组件二:mint-header;组件三:mint-swiper
6、v-model是什么?怎么使用? vue中标签怎么绑定事件?
答:可以实现双向绑定,指令(v-class、v-for、v-if、v-show、v-on)。vue的model层的data属性。绑定事件:<input @click=doLog() />
7、axios是什么?怎么使用?描述使用它实现登录功能的流程?
答:请求后台资源的模块。npm install axios -S装好,然后发送的是跨域,需在配置文件中config/index.js进行设置。后台如果是Tp5则定义一个资源路由。js中使用import进来,然后.get或.post。返回在.then函数中如果成功,失败则是在.catch函数中
8、axios+tp5进阶中,调用axios.post(‘api/user’)是进行的什么操作?axios.put(‘api/user/8′)呢?
答:跨域,添加用户操作,更新操作。
9、什么是RESTful API?怎么使用?
答:是一个api的标准,无状态请求。请求的路由地址是固定的,如果是tp5则先路由配置中把资源路由配置好。标准有:.post .put .delete
10、vuex是什么?怎么使用?哪种功能场景使用它?
答:vue框架中状态管理。在main.js引入store,注入。新建了一个目录store,….. export 。场景有:单页应用中,组件之间的状态。音乐播放、登录状态、加入购物车
11、mvvm框架是什么?它和其它框架(jquery)的区别是什么?哪些场景适合?
答:一个model+view+viewModel框架,数据模型model,viewModel连接两个
区别:vue数据驱动,通过数据来显示视图层而不是节点操作。
场景:数据操作比较多的场景,更加便捷
12、自定义指令(v-check、v-focus)的方法有哪些?它有哪些钩子函数?还有哪些钩子函数参数?
答:全局定义指令:在vue对象的directive方法里面有两个参数,一个是指令名称,另外一个是函数。组件内定义指令:directives
钩子函数:bind(绑定事件触发)、inserted(节点插入的时候触发)、update(组件内相关更新)
钩子函数参数:el、binding
13、说出至少4种vue当中的指令和它的用法?
答:v-if:判断是否隐藏;v-for:数据循环出来;v-bind:class:绑定一个属性;v-model:实现双向绑定
14、vue-router是什么?它有哪些组件?
答:vue用来写路由一个插件。router-link、router-view
15、导航钩子有哪些?它们有哪些参数?
答:导航钩子有:a/全局钩子和组件内独享的钩子。b/beforeRouteEnter、afterEnter、beforeRouterUpdate、beforeRouteLeave
参数:有to(去的那个路由)、from(离开的路由)、next(一定要用这个函数才能去到下一个路由,如果不用就拦截)最常用就这几种
16、Vue的双向数据绑定原理是什么?
答:vue.js 是采用数据劫持结合发布者-订阅者模式的方式,通过Object.defineProperty()来劫持各个属性的setter,getter,在数据变动时发布消息给订阅者,触发相应的监听回调。
具体步骤:
第一步:需要observe的数据对象进行递归遍历,包括子属性对象的属性,都加上 setter和getter
这样的话,给这个对象的某个值赋值,就会触发setter,那么就能监听到了数据变化
第二步:compile解析模板指令,将模板中的变量替换成数据,然后初始化渲染页面视图,并将每个指令对应的节点绑定更新函数,添加监听数据的订阅者,一旦数据有变动,收到通知,更新视图
第三步:Watcher订阅者是Observer和Compile之间通信的桥梁,主要做的事情是:
1、在自身实例化时往属性订阅器(dep)里面添加自己
2、自身必须有一个update()方法
3、待属性变动dep.notice()通知时,能调用自身的update()方法,并触发Compile中绑定的回调,则功成身退。
第四步:MVVM作为数据绑定的入口,整合Observer、Compile和Watcher三者,通过Observer来监听自己的model数据变化,通过Compile来解析编译模板指令,最终利用Watcher搭起Observer和Compile之间的通信桥梁,达到数据变化 -> 视图更新;视图交互变化(input) -> 数据model变更的双向绑定效果。
ps:16题答案同样适合”vue data是怎么实现的?”此面试题。
17、请详细说下你对vue生命周期的理解?
答:总共分为8个阶段创建前/后,载入前/后,更新前/后,销毁前/后。
创建前/后: 在beforeCreated阶段,vue实例的挂载元素$el和数据对象data都为undefined,还未初始化。在created阶段,vue实例的数据对象data有了,$el还没有。
载入前/后:在beforeMount阶段,vue实例的$el和data都初始化了,但还是挂载之前为虚拟的dom节点,data.message还未替换。在mounted阶段,vue实例挂载完成,data.message成功渲染。
更新前/后:当data变化时,会触发beforeUpdate和updated方法。
销毁前/后:在执行destroy方法后,对data的改变不会再触发周期函数,说明此时vue实例已经解除了事件监听以及和dom的绑定,但是dom结构依然存在
18、请说下封装 vue 组件的过程?
答:首先,组件可以提升整个项目的开发效率。能够把页面抽象成多个相对独立的模块,解决了我们传统项目开发:效率低、难维护、复用性等问题。
然后,使用Vue.extend方法创建一个组件,然后使用Vue.component方法注册组件。子组件需要数据,可以在props中接受定义。而子组件修改好数据后,想把数据传递给父组件。可以采用emit方法。
19、你是怎么认识vuex的?
答:vuex可以理解为一种开发模式或框架。比如php有thinkphp,java有spring等。
通过状态(数据源)集中管理驱动组件的变化(好比spring的IOC容器对bean进行集中管理)。
应用级的状态集中放在store中; 改变状态的方式是提交mutations,这是个同步的事物; 异步逻辑应该封装在action中。
20、vue-loader是什么?使用它的用途有哪些?
答:解析.vue文件的一个加载器,跟template/js/style转换成js模块。
用途:js可以写es6、style样式可以scss或less、template可以加jade等
21、请说出vue.cli项目中src目录每个文件夹和文件的用法?
答:assets文件夹是放静态资源;components是放组件;router是定义路由相关的配置;view视图;app.vue是一个应用主组件;main.js是入口文件
22、vue.cli中怎样使用自定义的组件?有遇到过哪些问题吗?
答:第一步:在components目录新建你的组件文件(smithButton.vue),script一定要export default {
第二步:在需要用的页面(组件)中导入:import smithButton from ‘../components/smithButton.vue’
第三步:注入到vue的子组件的components属性上面,components:{smithButton}
第四步:在template视图view中使用,<smith-button> </smith-button>
问题有:smithButton命名,使用的时候则smith-button。
23、聊聊你对Vue.js的template编译的理解?
答:简而言之,就是先转化成AST树,再得到的render函数返回VNode(Vue的虚拟DOM节点)
详情步骤:
首先,通过compile编译器把template编译成AST语法树(abstract syntax tree 即 源代码的抽象语法结构的树状表现形式),compile是createCompiler的返回值,createCompiler是用以创建编译器的。另外compile还负责合并option。
然后,AST会经过generate(将AST语法树转化成render funtion字符串的过程)得到render函数,render的返回值是VNode,VNode是Vue的虚拟DOM节点,里面有(标签名、子节点、文本等等)

阅读全文

与vue3源码解析书相关的资料

热点内容
什么软件可以修改pdf文件 浏览:865
命令行截图软件 浏览:732
程序员加班多 浏览:123
android设置view的背景 浏览:684
u盘加密工具哪个好 浏览:571
php生成html模板引擎 浏览:26
如何设置app封杀 浏览:823
手机将照片弄成压缩包 浏览:221
卡联购卡盟官网源码 浏览:867
网页弄成pdf 浏览:223
dos的删除命令 浏览:309
区块链的加密物联网传输 浏览:571
如何卸载桌面布局已定的app 浏览:678
vs重置命令 浏览:613
如何学会学习python 浏览:227
程序员钉钉 浏览:758
gcc编译器生成目标文件 浏览:157
怎么改服务器ip地址吗 浏览:56
cmd输入命令断开连接 浏览:911
二线大厂程序员员工年薪 浏览:988