解析vue data不可以使用箭頭函數(shù)問題
首先需要明確,a() {}和 b: () => {}是不同的
let obj = {
a() {},
// 相當(dāng)于
a:function() {},
b: () => {}
}
1 VUE.js 源碼解析
注意此處只設(shè)計(jì)核心代碼
這段代碼也是UMD實(shí)現(xiàn)原理,本文這里不是重點(diǎn),有興趣的可以自行探究。
(function (global, factory) {
typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() :
typeof define === 'function' && define.amd ? define(factory) :
(global.Vue = factory());
}(this, (function (){
'use strict';
console.log(this) //*undefined*
})))
解析一:
對(duì)于javascript來說,非嚴(yán)格模式下函數(shù)都會(huì)有一個(gè)this指向,不清楚的這里有傳送門this指向相關(guān)
說一下本文中涉及的this指向問題,如果不是嚴(yán)格模式,this應(yīng)該指向window,但是由于vue作者使用的是嚴(yán)格模式,所以他指向了undefined
以下是vue中data的實(shí)現(xiàn)原理
(function (global, factory) {
typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() :
typeof define === 'function' && define.amd ? define(factory) :
(global.Vue = factory());
}(this, (function (){
'use strict';
function getData(data,vm) {
return data.call(vm, vm)
}
function initData(params) {
data = vm._data = typeof data === 'function'
? getData(data, vm)
: data || {};
}
initData()
})))
也就是說每次新創(chuàng)建實(shí)例的時(shí)候都會(huì)去判斷是否有data函數(shù),如果有的話就會(huì)將其賦值給vm._data,心細(xì)的同學(xué)會(huì)發(fā)現(xiàn)對(duì)于Vmm實(shí)例來說是沒有data,而是有vm._data
es5函數(shù)和es6箭頭函數(shù)
var obj = {
a: () => {
'use strict';
console.log(this,'a')
},
b() {
console.log(this,'b')
},
c() {
// window
let e = () => {
console.log(this,'e')
}
return e
}
}
obj.a() // window
obj.b() // obj
obj.c()() // obj
對(duì)于普通函數(shù)(非嚴(yán)格模式下),this指向調(diào)用者,es6中的this指向聲明時(shí)的上下文環(huán)境。
結(jié)合以上兩點(diǎn)解析今天的問題
(function (global, factory) {
typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() :
typeof define === 'function' && define.amd ? define(factory) :
(global.Vue = factory());
}(this, (function (){
'use strict';
let vm = {}
var data = () => {
console.log(this);//undefined
return {
a: 1
}
}
function getData(data,vm) {
return data.call(vm, vm)
}
function initData(params) {
data = vm._data = typeof data === 'function'
? getData(data, vm)
: data || {};
}
initData()
console.log(vm);
})))
以上代碼說明你使用箭頭函數(shù)給data: () => {} this指向undefined的時(shí)候,是會(huì)賦值給vm._data,但是他會(huì)相當(dāng)于一個(gè)全局的,只要你不刷新頁面他就會(huì)緩存你的data。
如果我們使用data() {}this指向Vm實(shí)例,所以他會(huì)隨著實(shí)例更新。
總結(jié)
以上所述是小編給大家介紹的vue data不可以使用箭頭函數(shù)問題,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
相關(guān)文章
vue項(xiàng)目如何部署運(yùn)行到tomcat上
這篇文章主要介紹了vue項(xiàng)目如何部署運(yùn)行到tomcat上的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-01-01
解決vue admin element noCache設(shè)置無效的問題
今天小編就為大家分享一篇解決vue admin element noCache設(shè)置無效的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2019-11-11
Vue動(dòng)態(tài)組件與異步組件超詳細(xì)講解
這篇文章主要介紹了Vue動(dòng)態(tài)組件與異步組件,動(dòng)態(tài)組件是根據(jù)數(shù)據(jù)的變化,可以隨時(shí)切換不同的組件,比如咱們現(xiàn)在要展示一個(gè)文本框和輸入框,我們想要根據(jù)我們data中定義的值去決定是顯示文本框還是輸入框2023-03-03
vue項(xiàng)目中使用vue-i18n報(bào)錯(cuò)的解決方法
這篇文章主要給大家介紹了關(guān)于vue項(xiàng)目中使用vue-i18n報(bào)錯(cuò)的解決方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-01-01
基于Vuejs實(shí)現(xiàn)購(gòu)物車功能
這篇文章主要為大家詳細(xì)介紹了基于Vuejs實(shí)現(xiàn)購(gòu)物車功能的相關(guān)資料,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-08-08
Vuex實(shí)現(xiàn)數(shù)據(jù)增加和刪除功能
今天小編就為大家分享一篇Vuex實(shí)現(xiàn)數(shù)據(jù)增加和刪除功能,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2019-11-11
vue項(xiàng)目中跳轉(zhuǎn)到外部鏈接的實(shí)例講解
今天小編就為大家分享一篇vue項(xiàng)目中跳轉(zhuǎn)到外部鏈接的實(shí)例講解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-09-09
vue多功能渲染函數(shù)h()的使用和多種應(yīng)用場(chǎng)景
我們?cè)趘ue項(xiàng)目里面用HTML標(biāo)簽構(gòu)建頁面時(shí)最終會(huì)被轉(zhuǎn)化成vnode,而h()是直接創(chuàng)建vnode,因此h()能以一種更靈活的方式在各種各樣情景下構(gòu)建組件的渲染邏輯,并且能帶來性能方式的提升,本文介紹如何使用和列出具體的應(yīng)用場(chǎng)景,需要的朋友可以參考下2024-08-08

