欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

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

首先需要明確,a() {}和 b: () => {}是不同的

 let obj = {
   a() {},
   // 相當(dāng)于
   a:function() {},
   b: () => {}
}

1 VUE.js 源碼解析

注意此處只設(shè)計核心代碼

這段代碼也是UMD實現(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';
    console.log(this) //*undefined*
  })))

解析一:

對于javascript來說,非嚴(yán)格模式下函數(shù)都會有一個this指向,不清楚的這里有傳送門this指向相關(guān)

說一下本文中涉及的this指向問題,如果不是嚴(yán)格模式,this應(yīng)該指向window,但是由于vue作者使用的是嚴(yán)格模式,所以他指向了undefined

以下是vue中data的實現(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)建實例的時候都會去判斷是否有data函數(shù),如果有的話就會將其賦值給vm._data,心細(xì)的同學(xué)會發(fā)現(xiàn)對于Vmm實例來說是沒有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

對于普通函數(shù)(非嚴(yán)格模式下),this指向調(diào)用者,es6中的this指向聲明時的上下文環(huán)境。

結(jié)合以上兩點解析今天的問題

 (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的時候,是會賦值給vm._data,但是他會相當(dāng)于一個全局的,只要你不刷新頁面他就會緩存你的data。

如果我們使用data() {}this指向Vm實例,所以他會隨著實例更新。

總結(jié)

以上所述是小編給大家介紹的vue data不可以使用箭頭函數(shù)問題,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

相關(guān)文章

  • vue項目如何部署運行到tomcat上

    vue項目如何部署運行到tomcat上

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

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

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

    Vue動態(tài)組件與異步組件超詳細(xì)講解

    這篇文章主要介紹了Vue動態(tài)組件與異步組件,動態(tài)組件是根據(jù)數(shù)據(jù)的變化,可以隨時切換不同的組件,比如咱們現(xiàn)在要展示一個文本框和輸入框,我們想要根據(jù)我們data中定義的值去決定是顯示文本框還是輸入框
    2023-03-03
  • vue項目中使用vue-i18n報錯的解決方法

    vue項目中使用vue-i18n報錯的解決方法

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

    基于Vuejs實現(xiàn)購物車功能

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

    Vue2幾種常見開局方式詳解

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

    vue按需引入element Transfer 穿梭框

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

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

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

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

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

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

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

最新評論