亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

vue從使用到源碼實(shí)現(xiàn)教程詳解

 更新時(shí)間:2016年09月19日 09:21:38   作者:mzzzzq  
這篇文章主要介紹了vue從使用到源碼實(shí)現(xiàn)的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下

搭建環(huán)境

項(xiàng)目github地址

項(xiàng)目中涉及了json-server模擬get請(qǐng)求,用了vue-router;

關(guān)于Vue生命周期以及vue-router鉤子函數(shù)詳解

生命周期

1.0版本

1.哪些生命周期接口

init
Created
beforeCompile
Compiled
Ready
Attatched
Detached
beforeDestory
destoryed

2.執(zhí)行順序

1. 不具有keep-alive

進(jìn)入:

init->create->beforeCompile->complied->attatched->ready

移出:

beforeDestory->detached->destoryed;

2. 具有keep-alive

第一次的時(shí)候

進(jìn)入:

init->create->beforeCompile->complied->attatched->ready

移出:

detached;

之后的每次

進(jìn)入:

attatched

移出:

detached

鉤子函數(shù)

3.鉤子函數(shù)有哪些

data
activete
deactivate
canactivate
candeactivate

4.執(zhí)行順序

進(jìn)入:

canactivate->actiavte->date

移出:

candeactivate->deactiavte

兩者一起出現(xiàn)

5.對(duì)于一個(gè)組件A里面有子組件B,當(dāng)這個(gè)組件A進(jìn)行移入和移出操作時(shí),組件之間的生命周期喝鉤子函數(shù)的執(zhí)行順序參考如下:

例如

A.vue

<div>
<B></B>
</div>

備注:下面括號(hào)里的是嵌套的子組件

1. 不具有keep-alive:

移入:

1. canActivate;
2. init;
3. create;
4. beforeCompile;
5. (嵌套子組件:init,create,beforeCompile,compile);
6. compile;
7. activate;
8. data;
9. attached;
10. (子組件attached);
11. (子組件ready);
12. ready;

移出:

13. canDeactivate;
14. deactivate;
15. beforeDestroy;
16. (子組件beforeDestroy);
17. (子組件destoryed);
18. detached;
19. (子組件detached);
20. destoryed;

2. 具有keep-alive:

移入:

1. canActivate;
2. activate;
3. data;
4. attached;
5. (子組件attached);

移出:

6. canDeactivate;
7. deactivate;
8. detached;
9. (子組件detached);

6.鉤子函數(shù)activate和data的執(zhí)行順序

涉及鉤子函數(shù)異步 resolve 規(guī)則:

1.如果鉤子返回一個(gè) Promise,則鉤子何時(shí) resolve 取決于該 Promise 何時(shí) resolve。

2.如果鉤子既不返回 Promise,也沒有任何參數(shù),則該鉤子將被同步 resolve。

3.如果鉤子不返回 Promise,但是有一個(gè)參數(shù)(transition),則鉤子會(huì)等到transition.next(),transition.abort()或是transition.redirect()之一被調(diào)用才 resolve。

4.在驗(yàn)證類的鉤子,比如canActivate,canDeactivate以及全局 beforeEach 鉤子中,如果返回值是一個(gè)布爾值 (Boolean),也會(huì)使得鉤子同步 resolve。

這里寫圖片描述 
這里寫圖片描述 
這里寫圖片描述

7.根據(jù)什么可以確保界面已經(jīng)更新完成,也就是說掛在完成

執(zhí)行生命周期attached說明已掛載

雙向綁定與渲染機(jī)制

1.數(shù)據(jù)的監(jiān)聽和觸發(fā)(訂閱和發(fā)布o(jì)bserver)

src目錄下observer:

1. array.js

2. dep.js;(實(shí)現(xiàn)一個(gè)發(fā)布訂閱對(duì)象)

3. index.js;(利用Object.defineProperty這個(gè)API,并為此屬性設(shè)計(jì)一個(gè)特殊的 getter/setter,然后在 setter 里觸發(fā)一個(gè)函數(shù),達(dá)到監(jiān)聽的效果);

下面是這部分的源碼

Object.defineProperty(obj, key, {
enumerable: true,
configurable: true,
get: function reactiveGetter () {
var value = getter ? getter.call(obj) : val
if (Dep.target) {
dep.depend()
if (childOb) {
childOb.dep.depend()
}
if (isArray(value)) {
for (var e, i = 0, l = value.length; i < l; i++) {
e = value[i]
e && e.__ob__ && e.__ob__.dep.depend()
}
}
}
return value
},
set: function reactiveSetter (newVal) {
var value = getter ? getter.call(obj) : val
if (newVal === value) {
return
}
if (setter) {
setter.call(obj, newVal)
} else {
val = newVal
}
childOb = observe(newVal)
dep.notify()
}
})

簡(jiǎn)化上面的監(jiān)聽與觸發(fā)代碼如下:

function notidy(obj,key){
console.log(key+" has changed");
console.log(key+" now is: "+obj[key]);
}
function ToData(key,val){
var ob=this;
Object.defineProperty(ob,key,{
enumerable:true,
configurable:true,
get:function(){
return val;
},
set:function(newval){
if(newval==val){
return;
}
val=newval;
notidy(this,key);
}
})
}

src目錄下directive.js

在directive中可以看到一系列解析出來的屬性,而directive的實(shí)例化可以在utils/lifecycle.js中看到。

下面這段代碼在Directive.prototype._bind中

var watcher = this._watcher = new Watcher(
this.vm,
this.expression,
this._update, // callback
{
filters: this.filters,
twoWay: this.twoWay,
deep: this.deep,
preProcess: preProcess,
postProcess: postProcess,
scope: this._scope
}
)
// v-model with inital inline value need to sync back to
// model instead of update to DOM on init. They would
// set the afterBind hook to indicate that.
if (this.afterBind) {
this.afterBind()
} else if (this.update) {
this.update(watcher.value)
}
Directive.prototype.set = function (value) {
/* istanbul ignore else */
if (this.twoWay) {
this._withLock(function () {
this._watcher.set(value)
})
} else if (process.env.NODE_ENV !== 'production') {
warn(
'Directive.set() can only be used inside twoWay' +
'directives.'
)
}
}

src目錄下Watch.js:

從下面的代碼可以找到watcher對(duì)象通過addDep方法實(shí)現(xiàn)訂閱

Watcher.prototype.addDep = function (dep) {
var id = dep.id
if (!this.newDepIds.has(id)) {
this.newDepIds.add(id)
this.newDeps.push(dep)
if (!this.depIds.has(id)) {
dep.addSub(this)
}
}
}

2.前面說那么多關(guān)于雙向綁定,其實(shí)這也是VUE內(nèi)部的渲染機(jī)制,總結(jié)如下

1. 通過 observer 對(duì) data 進(jìn)行了監(jiān)聽,并且提供訂閱某個(gè)數(shù)據(jù)項(xiàng)的變化的能力

2. 把 template 解析成一段 document fragment,然后解析其中的 directive,得到每一個(gè) directive 所依賴的數(shù)據(jù)項(xiàng)及其更新方法。比如 v-text="message" 被解析之后 (這里僅作示意,實(shí)際程序邏輯會(huì)更嚴(yán)謹(jǐn)而復(fù)雜):所依賴的數(shù)據(jù)項(xiàng)this.$data.message,以及相應(yīng)的視圖更新方法 node.textContent = this.$data.message

3. 通過 watcher 把上述兩部分結(jié)合起來,即把 directive 中的數(shù)據(jù)依賴訂閱在對(duì)應(yīng)數(shù)據(jù)的 observer 上,這樣當(dāng)數(shù)據(jù)變化的時(shí)候,就會(huì)觸發(fā) observer,進(jìn)而觸發(fā)相關(guān)依賴對(duì)應(yīng)的視圖更新方法,最后達(dá)到模板原本的關(guān)聯(lián)效果。

3.vue是如何改進(jìn)了v-for具有相同數(shù)據(jù)渲染出錯(cuò)的?

數(shù)組的渲染

未使用track-by的數(shù)組渲染內(nèi)部緩存的默認(rèn)id是數(shù)組的值value,意味著如果數(shù)組中存在相同的值,通過id獲取的是相同的一個(gè)fragement片段,最后通過insertBefore操作DOM由于是相同的一個(gè)實(shí)例,故不會(huì)生效。

<div>
<ul id='test'>
<li id="child1">child1</li>
<li id="child">child2</li>
</ul>
</div>
<script>
_element1=document.getElementById('child1');
_element2=document.getElementById('child2');
document.getElementById('test').insertBefore(_element1,_element2);
</script>

渲染的結(jié)果是child2在child1前面

使用track-by目的是自定義這個(gè)內(nèi)部的id,使得數(shù)組中具有相同的值的幾項(xiàng)都不會(huì)選擇到相同的實(shí)例,對(duì)于使用track-by='$index'還是其他唯一區(qū)分的id值有一定的區(qū)別,各有好處。

使用$index使得反轉(zhuǎn)的數(shù)據(jù)沒有移動(dòng)操作,而對(duì)于使用其他的id在順序不一樣的時(shí)候會(huì)有相應(yīng)的移動(dòng)操作。

對(duì)象的渲染

對(duì)象一般使用鍵作為內(nèi)部緩存對(duì)象的id,通過track-by也可以自定義這個(gè)id提高性能。

vm.model = {
a: { id: 1, val: "model1"},
b: { id: 2, val: "model2"},
c: { id: 3, val: "model2"},
}

列表更新

vm.model = {
d: { id: 1, val: "model1"},
e: { id: 2, val: "model2"},
f: { id: 3, val: "model2"}
}

以上所述是小編給大家介紹的vue從使用到源碼實(shí)現(xiàn)教程詳解,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!

相關(guān)文章

  • vue組件之間通信方式實(shí)例總結(jié)【8種方式】

    vue組件之間通信方式實(shí)例總結(jié)【8種方式】

    這篇文章主要介紹了vue組件之間通信方式,結(jié)合實(shí)例形式總結(jié)分析了vue.js的8種組件通信方式與相關(guān)操作注意事項(xiàng),需要的朋友可以參考下
    2019-02-02
  • vue中element 上傳功能的實(shí)現(xiàn)思路

    vue中element 上傳功能的實(shí)現(xiàn)思路

    這篇文章主要介紹了vue中element 的上傳功能的實(shí)現(xiàn)思路,本文大概通過兩種實(shí)現(xiàn)思路,具體內(nèi)容詳情大家跟隨腳本之家小編一起看看吧
    2018-07-07
  • vue多層嵌套路由實(shí)例分析

    vue多層嵌套路由實(shí)例分析

    這篇文章主要介紹了vue多層嵌套路由,結(jié)合實(shí)例形式分析了vue.js多層嵌套路由的概念、原理及相關(guān)操作技巧,需要的朋友可以參考下
    2019-03-03
  • vue3腳手架簡(jiǎn)單靜態(tài)路由解讀

    vue3腳手架簡(jiǎn)單靜態(tài)路由解讀

    這篇文章主要介紹了vue3腳手架簡(jiǎn)單靜態(tài)路由,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-10-10
  • Vue指令之v-for的使用說明

    Vue指令之v-for的使用說明

    這篇文章主要介紹了Vue指令之v-for的使用說明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • 淺談Vue3.0新版API之composition-api入坑指南

    淺談Vue3.0新版API之composition-api入坑指南

    這篇文章主要介紹了Vue3.0新版API之composition-api入坑指南,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-04-04
  • vue前端框架vueuse的useScroll函數(shù)使用源碼分析

    vue前端框架vueuse的useScroll函數(shù)使用源碼分析

    這篇文章主要為大家介紹了vueuse的useScroll函數(shù)源碼分析詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-08-08
  • Vue為何棄用Ajax,選擇Axios?ajax與axios的區(qū)別?

    Vue為何棄用Ajax,選擇Axios?ajax與axios的區(qū)別?

    ajax技術(shù)實(shí)現(xiàn)了局部數(shù)據(jù)的刷新,axios實(shí)現(xiàn)了對(duì)ajax的封裝;axios有的ajax都有,ajax有的axios不一定有??偨Y(jié)一句話就是axios是ajax,ajax不止axios。
    2023-01-01
  • Vue中偵聽器的基本用法示例

    Vue中偵聽器的基本用法示例

    隨著Vue的使用越來越多,對(duì)Vue的其他知識(shí)點(diǎn)也開始逐漸多了解一點(diǎn),這次做頁面上的計(jì)算,用了Watch偵聽器,這篇文章主要給大家介紹了關(guān)于Vue中偵聽器基本用法的相關(guān)資料,需要的朋友可以參考下
    2021-08-08
  • elementui簡(jiǎn)易介紹(推薦)

    elementui簡(jiǎn)易介紹(推薦)

    ElementUI是一套基于VUE2.0的桌面端組件庫,ElementUI提供了豐富的組件幫助開發(fā)人員快速構(gòu)建功能強(qiáng)大、風(fēng)格統(tǒng)一的頁面,本文給大家分享elementui簡(jiǎn)易介紹,感興趣的朋友一起看看吧
    2024-01-01

最新評(píng)論