这篇文章给大家分享的是有关vue实现的步骤是什么的内容。小编觉得挺实用的,因此分享给大家做个参考。一起跟随小编过来看看吧。
vue是当今热门的框架,他可以进行数据双向绑定,为什么vue会大受欢迎,我知道的原因大致如下?
1。传统改变dom结构的操作是非常浪费性能的操作(就是慢)
2。把dom结构改变的逻辑放在js层来做可以提高性能。
3。数据和视图的分离更符合面向对象的编程,mvvm
vue的实现也是和反应一样用虚拟dom来实现的,至于什么是虚拟dom,就是用js通过模板渲染而成的dom。
vue实现的步骤大概是这三步:
1,响应式:vue怎么监听到队伍的每个属性值的变化?
2,模板引擎:vue的模板如何解析的,指令是如何处理的?
3模板渲染:如何把数据里的数据加入模板并渲染成html ?
<强>第一步:响应式强>
响应式的实现主要是依靠一个对象的方法:
<强> Object.defineProperty 强>
这个方法能够监听对象中属性的变化而进行逻辑处理
圆顶如下:
var obj={} var _name=& # 39; zhangsan& # 39; Object.defineProperty (obj & # 39;名字# 39;,{ 得到:函数(){ console.log(& # 39;得到# 39;) 返回_name }, 设置:函数(newVal) { console.log(& # 39;集# 39;) _name=newVal } })
这里你改变名称的值或者访问名字的值就会有打印信息
而在vue中模拟实现,大概是这样的:
var vm={} var data=https://www.yisu.com/zixun/{名称:“张三”,年龄:20} var关键,价值; (关键数据){ (函数(关键){ Object.defineProperty (vm,钥匙,{//绑定到vm上 得到:函数(){ console.log(得到) 返回数据(关键); }, 设置:函数(newVal) { console.log('设置'); (例子)=newVal数据 } }) })(关键)//闭包处理 }
其实学过java的同学肯定对这个不陌生,java的类里面可以直接生成获取和设置方法
第二步:解析模板
模板必须要转化成js代码,因为:
1。逻辑判断(v, v代表),必须要用js才能实现。
2。虚拟dom的渲染,必须要使用js才能实现。(渲染函数)
模板1
& lt; div id=癮pp"比; & lt; p>{{价格}}& lt;/p> & lt;/div>
模板1转化的呈现
,(这){//这就是vm 返回_c ( & # 39;p # 39; { attrs: {& # 39; id # 39;: & # 39;应用# 39;} }, (//_c是createElement//_v是createTextVNode//_是toString方法 _c (& # 39; p # 39;, [_v(_(价格)))) ] ) }
模板2
& lt; div id=癮pp"比; & lt; div> & lt;输入v模型=皌itle"祝辞 v & lt;按钮:点击=癮dd"祝辞submit & lt;/div> & lt; div> & lt; ul> & lt;李v=跋頻ist"在{{项}}& lt;/li> & lt;/ul> & lt;/div> & lt;/div>
模板2转化的呈现
与(){ 返回_c ( & # 39;p # 39; {attrs: {“id":“app"}}, ( _c ( & # 39;p # 39; ( _c ( & # 39;输入# 39; {//指令 指示:[ { 名称:“model", rawName:“v-model" 值:(标题),//vm.title 表情:“title" } ], domProps: { “value"://vm.title(标题) },> vm._update (Vnode) { const prevVonde=vm._Vnode vm._Vnode=Vnode; 如果(! prevVnode){//如果没有之前的vnode,第一次渲染 vm。$ el=vm._patch_ (vm。el美元,Vnode) 其他}{ vm。el美元=vm._patch_ (prevVnode Vnode) } } 函数updataComponent () {//vm._reander就是解析模板的仁德函数,返回了一个vnode vm._update (vm._render ()) }
这里的vm_。patch_里面就是复杂的diff算法了。根据dom的差别来渲染,里面使用来很多的递归调用,而且里面最要涉及到很多效率问题,天下武功为快不破嘛。
感谢各位的阅读!关于vue实现的步骤是什么就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到吧!