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

解析vue data不可以使用箭頭函數(shù)問(wèn)題

 更新時(shí)間:2018年07月03日 11:52:30   作者:Just_do  
這篇文章主要介紹了vue data不可以使用箭頭函數(shù)問(wèn)題,本文通過(guò)源碼解析給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下

首先需要明確,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指向,不清楚的這里有傳送門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)文章

  • vue項(xiàng)目如何部署運(yùn)行到tomcat上

    vue項(xiàng)目如何部署運(yùn)行到tomcat上

    這篇文章主要介紹了vue項(xiàng)目如何部署運(yùn)行到tomcat上的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-01-01
  • 解決vue admin element noCache設(shè)置無(wú)效的問(wèn)題

    解決vue admin element noCache設(shè)置無(wú)效的問(wèn)題

    今天小編就為大家分享一篇解決vue admin element noCache設(shè)置無(wú)效的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2019-11-11
  • Vue動(dòng)態(tài)組件與異步組件超詳細(xì)講解

    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ò)的解決方法

    vue項(xiàng)目中使用vue-i18n報(bào)錯(cuò)的解決方法

    這篇文章主要給大家介紹了關(guān)于vue項(xiàng)目中使用vue-i18n報(bào)錯(cuò)的解決方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-01-01
  • 基于Vuejs實(shí)現(xiàn)購(gòu)物車功能

    基于Vuejs實(shí)現(xiàn)購(gòu)物車功能

    這篇文章主要為大家詳細(xì)介紹了基于Vuejs實(shí)現(xiàn)購(gòu)物車功能的相關(guān)資料,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-08-08
  • Vue2幾種常見開局方式詳解

    Vue2幾種常見開局方式詳解

    這篇文章主要為大家詳細(xì)介紹了Vue2幾種常見開局方式,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-09-09
  • vue按需引入element Transfer 穿梭框

    vue按需引入element Transfer 穿梭框

    這篇文章主要介紹了vue按需引入element Transfer 穿梭框的相關(guān)資料,需要的朋友可以參考下
    2017-09-09
  • Vuex實(shí)現(xiàn)數(shù)據(jù)增加和刪除功能

    Vuex實(shí)現(xiàn)數(shù)據(jù)增加和刪除功能

    今天小編就為大家分享一篇Vuex實(shí)現(xiàn)數(shù)據(jù)增加和刪除功能,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2019-11-11
  • vue項(xiàng)目中跳轉(zhuǎn)到外部鏈接的實(shí)例講解

    vue項(xiàng)目中跳轉(zhuǎn)到外部鏈接的實(shí)例講解

    今天小編就為大家分享一篇vue項(xiàng)目中跳轉(zhuǎn)到外部鏈接的實(shí)例講解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-09-09
  • vue多功能渲染函數(shù)h()的使用和多種應(yīng)用場(chǎng)景

    vue多功能渲染函數(shù)h()的使用和多種應(yīng)用場(chǎng)景

    我們?cè)趘ue項(xiàng)目里面用HTML標(biāo)簽構(gòu)建頁(yè)面時(shí)最終會(huì)被轉(zhuǎn)化成vnode,而h()是直接創(chuàng)建vnode,因此h()能以一種更靈活的方式在各種各樣情景下構(gòu)建組件的渲染邏輯,并且能帶來(lái)性能方式的提升,本文介紹如何使用和列出具體的應(yīng)用場(chǎng)景,需要的朋友可以參考下
    2024-08-08

最新評(píng)論