亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術(shù)文章
文章詳情頁

Vue組件為什么data必須是一個函數(shù)

瀏覽:81日期:2023-01-13 18:14:13

前言

我們需要先復(fù)習(xí)下原型鏈的知識,其實這個問題取決于 js ,而并非是 vue 。

function Component(){ this.data = this.data}Component.prototype.data = { name:’jack’, age:22,}

首先我們達成一個共識(沒有這個共識,請補充下 js 原型鏈部分的知識):

實例它們構(gòu)造函數(shù)內(nèi)的this內(nèi)容是不一樣的。 Component.prototype ,這類底下的方法或者值,都是所有實例公用的。

解開疑問

基于此,我們來看看這個問題:

function Component(){ }Component.prototype.data = { name:’jack’, age:22,}var componentA = new Component();var componentB = new Component();componentA.data.age=55;console.log(componentA,componentB)

此時,componentA 和 componentB data之間指向了同一個內(nèi)存地址,age 都變成了 55, 導(dǎo)致了問題!

接下來很好解釋為什么 vue 組件需要 function 了:

function Component(){ this.data = this.data()}Component.prototype.data = function (){ return { name:’jack’, age:22,}}var componentA = new Component();var componentB = new Component();componentA.data.age=55;console.log(componentA,componentB)

此時,componentA 和 componentB data之間相互獨立, age 分別是 55 和 22 ,沒有問題!

總結(jié)

自己突然對這個問題懵逼,不過事后想了想還是自己基礎(chǔ)知識忘得太快。以前學(xué)習(xí) js 的時候,最基礎(chǔ)的:構(gòu)造函數(shù)內(nèi)和原型之間的區(qū)別都模糊了。想不到 vue 這個小問題讓我溫故而知新了一次。

到此這篇關(guān)于Vue組件為什么data必須是一個函數(shù)的文章就介紹到這了,更多相關(guān)Vue組件data是函數(shù)內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: Vue
相關(guān)文章:
主站蜘蛛池模板: 色久视频 | 国产精品亚洲精品观看不卡 | 精品三区 | 中文字幕第一页亚洲 | 黄色网址在线免费看 | 日韩国产综合 | 日本一级大黄毛片一级 | 成熟热自由日本语亚洲人 | 黄色短视频在线观看 | 大陆一级毛片免费视频观看 | 一级视频在线观看 | 亚洲国产一二三 | 日韩一级a毛片欧美一级 | 91久久国产综合精品 | 九九精品视频在线观看九九 | 国产 欧美 日产中文 | 黄色短视频免费看 | 黄色生活毛片 | 精品日本亚洲一区二区三区 | 欧美yw193.c㎝在线观看 | 色九九亚洲偷偷动态图 | 亚洲wuma| 亚洲国产精品67194成人 | 极品主播的慰在线播放 | 免费日韩在线 | 国产免费小视频在线观看 | 久久视频在线免费观看 | 国产黄色片在线免费观看 | 99re最新地址获取精品 | 久久天天躁狠狠躁夜夜中文字幕 | 国产美女主播一级成人毛片 | 92手机看片福利永久国产 | 内地精品露脸自拍视频香蕉 | 12306播播影视播播影院午夜 | 中国欧美一级毛片免费 | 黄色aaaaa | 国产原创在线观看 | 亚洲欧美在线观看 | 黑人一区二区三区 | 久久精品午夜视频 | 亚洲在线观看一区二区 |