組件--為什么組件中的data是一個函數(shù)快骗??塔次?

首先方篮,組件是用于代碼的復(fù)用,提高代碼的維護(hù)励负。在不同的頁面藕溅,我們可能使用同一個組件,每個組件中有可能有相同的屬性代碼继榆,我們操作這些屬性來進(jìn)行值的一些更改巾表,例如下面的例子

const obj = {
    count:0
  }
  //注冊并掛載到全局的Vue上
  Vue.component('spn',{
    template:`#mycpn`,
    data(){
      return obj
    },
    methods:{
      increment(){
        this.count++
      },
      decrement(){
        this.count--
      }
    }
  })
  let app = new Vue({
    el: "#app",
  })
  //在設(shè)計這個vue的時候,考慮到組件之間更改屬性的過程中,如果直接更改屬性會造成其他用到組件的地方因為前一個數(shù)據(jù)的變化裹虫,后面組件跟著變化的情況
  //干脆直接設(shè)計成為調(diào)用函數(shù)贷岸,每次調(diào)用的時候變量的引用都是不同的,這樣每次在進(jìn)行修改組件屬性的時候惠猿,其他的組件屬性不會發(fā)生更改

上面代碼的效果圖


image.png

上面代碼當(dāng)我點擊加號或者減號會出現(xiàn)什么樣的結(jié)果呢,如下


image.png

當(dāng)我點擊加號的時候负间,這兩個數(shù)字都進(jìn)行了加1操作偶妖,這是我們希望看到的嗎,實際工作中我們也是不希望有這樣的事兒發(fā)生政溃,因為組件是相對封閉的一個空間趾访,他自己里面執(zhí)行的邏輯不能被其他引用了該組件的操作所影響,那么我們就來研究一下為什么會發(fā)生這樣的情況董虱。

首先我們來看一個js代碼

  function getMsg(){
    return {
      name:"cxy",
      age:18
    }
   }

 let obj1 = getMsg();
 let obj2 = getMsg();
 let obj3 = getMsg();

 obj1.name="coder"
  console.log(obj1.name)
  console.log(obj2.name)
  console.log(obj3.name)

我調(diào)用了三次getMsg()方法扼鞋,返回了三個對象申鱼,我要驗證這三個對象是否是屬于同一個,我將其中一個對象的屬性改了云头,看其他對象的屬性是否會跟著改變捐友,答案我們可以看到,他們是不會改變的溃槐,如下


image.png

這到底是什么原因呢匣砖?理解這個問題,我們要首先了解內(nèi)存模型昏滴,在進(jìn)行方法調(diào)用返回對象的時候猴鲫,每次返回的對象都是從棧空間里面創(chuàng)建的臨時變量谣殊,也就是一個內(nèi)存地址拂共,如下


Snipaste_2020-06-04_08-41-37.png

來看一下他的反例

  //這里直接返回的是臨時開辟的一塊內(nèi)存地址,而且地址不會發(fā)生改變
  const msg = {
    name:"cxy",
    age:18
  }

  function getMsg(){
    return msg;
  }

 let obj1 = getMsg();
 let obj2 = getMsg();
 let obj3 = getMsg();

 obj1.name="coder"
  console.log(obj1.name)
  console.log(obj2.name)
  console.log(obj3.name)

打印結(jié)果


image.png

這又是為什么呢蟹倾?請看下圖

image.png

那么也就解釋了為什么data是一個函數(shù)匣缘,而不是一個對象,是對象的話鲜棠,就直接返回的同一個內(nèi)存地址肌厨,導(dǎo)致同一組件在不同地方使用,對象屬性之間會產(chǎn)生影響豁陆。歡迎小伙伴兒指出我理解的不是很正確的地方柑爸,喜歡的話可以點贊支持一下,哈哈哈

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末盒音,一起剝皮案震驚了整個濱河市表鳍,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌祥诽,老刑警劉巖譬圣,帶你破解...
    沈念sama閱讀 222,183評論 6 516
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異雄坪,居然都是意外死亡厘熟,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,850評論 3 399
  • 文/潘曉璐 我一進(jìn)店門维哈,熙熙樓的掌柜王于貴愁眉苦臉地迎上來绳姨,“玉大人,你說我怎么就攤上這事阔挠∑” “怎么了?”我有些...
    開封第一講書人閱讀 168,766評論 0 361
  • 文/不壞的土叔 我叫張陵购撼,是天一觀的道長跪削。 經(jīng)常有香客問我谴仙,道長,這世上最難降的妖魔是什么碾盐? 我笑而不...
    開封第一講書人閱讀 59,854評論 1 299
  • 正文 為了忘掉前任狞甚,我火速辦了婚禮,結(jié)果婚禮上廓旬,老公的妹妹穿的比我還像新娘。我一直安慰自己谐腰,他們只是感情好孕豹,可當(dāng)我...
    茶點故事閱讀 68,871評論 6 398
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著十气,像睡著了一般励背。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上砸西,一...
    開封第一講書人閱讀 52,457評論 1 311
  • 那天叶眉,我揣著相機(jī)與錄音,去河邊找鬼芹枷。 笑死衅疙,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的鸳慈。 我是一名探鬼主播饱溢,決...
    沈念sama閱讀 40,999評論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼走芋!你這毒婦竟也來了绩郎?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,914評論 0 277
  • 序言:老撾萬榮一對情侶失蹤翁逞,失蹤者是張志新(化名)和其女友劉穎肋杖,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體挖函,經(jīng)...
    沈念sama閱讀 46,465評論 1 319
  • 正文 獨居荒郊野嶺守林人離奇死亡状植,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,543評論 3 342
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了挪圾。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片浅萧。...
    茶點故事閱讀 40,675評論 1 353
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖哲思,靈堂內(nèi)的尸體忽然破棺而出洼畅,到底是詐尸還是另有隱情,我是刑警寧澤棚赔,帶...
    沈念sama閱讀 36,354評論 5 351
  • 正文 年R本政府宣布帝簇,位于F島的核電站徘郭,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏丧肴。R本人自食惡果不足惜残揉,卻給世界環(huán)境...
    茶點故事閱讀 42,029評論 3 335
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望芋浮。 院中可真熱鬧抱环,春花似錦、人聲如沸纸巷。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,514評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽瘤旨。三九已至梯啤,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間存哲,已是汗流浹背因宇。 一陣腳步聲響...
    開封第一講書人閱讀 33,616評論 1 274
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留祟偷,地道東北人察滑。 一個月前我還...
    沈念sama閱讀 49,091評論 3 378
  • 正文 我出身青樓,卻偏偏與公主長得像肩袍,于是被迫代替她去往敵國和親杭棵。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,685評論 2 360