解析vue data不可以使用箭頭函數(shù)問(wèn)題
首先需要明確,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來(lái)說(shuō),非嚴(yán)格模式下函數(shù)都會(huì)有一個(gè)this指向,不清楚的這里有傳送門(mén)this指向相關(guān)
說(shuō)一下本文中涉及的this指向問(wèn)題,如果不是嚴(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()
})))
也就是說(shuō)每次新創(chuàng)建實(shí)例的時(shí)候都會(huì)去判斷是否有data函數(shù),如果有的話就會(huì)將其賦值給vm._data,心細(xì)的同學(xué)會(huì)發(fā)現(xiàn)對(duì)于Vmm實(shí)例來(lái)說(shuō)是沒(méi)有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)解析今天的問(wè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);
})))
以上代碼說(shuō)明你使用箭頭函數(shù)給data: () => {} this指向undefined的時(shí)候,是會(huì)賦值給vm._data,但是他會(huì)相當(dāng)于一個(gè)全局的,只要你不刷新頁(yè)面他就會(huì)緩存你的data。
如果我們使用data() {}this指向Vm實(shí)例,所以他會(huì)隨著實(shí)例更新。
總結(jié)
以上所述是小編給大家介紹的vue data不可以使用箭頭函數(shù)問(wèn)題,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
相關(guān)文章
element組件中自定義組件的樣式不生效問(wèn)題(vue scoped scss無(wú)效)
這篇文章主要介紹了解決element組件中自定義組件的樣式不生效問(wèn)題(vue scoped scss無(wú)效),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-09-09
vue3+Element?Plus?v-model實(shí)現(xiàn)父子組件數(shù)據(jù)同步的案例代碼
這篇文章主要介紹了vue3+Element?Plus?v-model實(shí)現(xiàn)父子組件數(shù)據(jù)同步,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2024-01-01
vue二級(jí)菜單導(dǎo)航點(diǎn)擊選中事件的方法
今天小編就為大家分享一篇vue二級(jí)菜單導(dǎo)航點(diǎn)擊選中事件的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-09-09
Element-ui tree組件自定義節(jié)點(diǎn)使用方法代碼詳解
本文通過(guò)實(shí)例代碼給大家介紹了Element-ui tree組件自定義節(jié)點(diǎn)使用方法 ,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2018-09-09
vue下使用nginx刷新頁(yè)面404的問(wèn)題解決
這篇文章主要介紹了vue下使用nginx刷新頁(yè)面404的問(wèn)題解決,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-08-08
vue使用less報(bào)錯(cuò):Inline JavaScript is not ena
這篇文章主要介紹了vue使用less報(bào)錯(cuò):Inline JavaScript is not enabled問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-01-01
vue中實(shí)現(xiàn)路由跳轉(zhuǎn)的三種方式超詳細(xì)教程
這篇文章主要介紹了vue中實(shí)現(xiàn)路由跳轉(zhuǎn)的三種方式超詳細(xì)教程,其中聲明式router-link實(shí)現(xiàn)跳轉(zhuǎn)最簡(jiǎn)單的方法,可用組件router-link來(lái)替代a標(biāo)簽,每種方式給大家講解的非常詳細(xì)需要的朋友可以參考下2022-11-11
Vue.js axios響應(yīng)攔截如何獲取返回狀態(tài)碼
這篇文章主要介紹了Vue.js axios響應(yīng)攔截如何獲取返回狀態(tài)碼問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-01-01

