vue实现的步骤是什么

  介绍

这篇文章给大家分享的是有关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实现的步骤是什么就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到吧!

vue实现的步骤是什么