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

詳解vue.js之props傳遞參數(shù)

 更新時(shí)間:2017年12月12日 08:33:43   投稿:laozhang  
給大家詳細(xì)分析了vue.js之props傳遞參數(shù)的相關(guān)知識(shí)以及問(wèn)題解決方法,需要的朋友參考下吧。

本篇文章通過(guò)demo實(shí)例給大家詳細(xì)分析了props傳遞參數(shù)的用法以及遇到問(wèn)題后的解決辦法,以下是全部?jī)?nèi)容。

前段時(shí)間用vue做一個(gè)后臺(tái)管理系統(tǒng),其中每一頁(yè)都需要一個(gè)表格來(lái)展示信息。自然就想到了將表格提取出來(lái)做成公共組件,將不同頁(yè)面的數(shù)據(jù)傳入進(jìn)行渲染,達(dá)到復(fù)用的目的。

demo地址

1. 問(wèn)題發(fā)現(xiàn)

在父組件中,需要向表格組件傳遞的數(shù)據(jù)有表格的內(nèi)容數(shù)據(jù)tableData,表格的頁(yè)面數(shù)據(jù)page。

<div>
 <my-table :table-data="tableData" :page-info="pageInfo" id="myTable"></my-table>
</div>

其中tableData是個(gè)Array對(duì)象,是所有需要在表格中展示的數(shù)據(jù)對(duì)象組成的一個(gè)數(shù)組。而pageInfo是個(gè)Object對(duì)象,包含了表格頁(yè)面信息。在父組件對(duì)兩個(gè)數(shù)據(jù)對(duì)如下初始化,形式如下

tableData:[],
pageInfo: {
 current: 1, // 當(dāng)前是第幾頁(yè)
 total: 100, // 數(shù)據(jù)對(duì)象的總數(shù)
 size: 20 // 每頁(yè)顯示的數(shù)量
}

 

按照官方文檔上的說(shuō)明,prop是單向綁定的,不應(yīng)該在子組件內(nèi)部改變prop。之所以有想修改prop中數(shù)據(jù)的沖動(dòng),主要是prop作為初始值傳入后,子組件想把它當(dāng)作局部數(shù)據(jù)來(lái)用。對(duì)于這種情況,官方的說(shuō)法是定義一個(gè)局部變量,并用 prop 的值初始化它:

props: ['tableData', 'pageInfo'],
data() {
 return {
  tData: this.tableData,
  page: this.pageInfo
 }
}

然后根據(jù)官方文檔的說(shuō)法,當(dāng)每次父組件更新時(shí),子組件的所有prop都會(huì)更新為最新值。而tableData和pageInfo的信息是異步通過(guò)api從server端獲取的:

{
 error: 0,
 msg: "調(diào)用成功.",
 data: {
  restrictioninfo: [...],
  total: 42
 }
}

 

因此當(dāng)獲取到數(shù)據(jù)時(shí)父組件需要改變傳入子組件中的值:

me.tableData = Json.data.restrictioninfo;
me.pageInfo.total = Json.data.total;

按理說(shuō)這時(shí)候子組件中的值應(yīng)該更新成server返回的值,但是子組件頁(yè)面的總數(shù)更新了,但table數(shù)據(jù)依然是初始化時(shí)的空數(shù)組。(黑人問(wèn)號(hào)???)


。

2.賦值與綁定

首先需要定位數(shù)據(jù)是在哪個(gè)地方出了問(wèn)題,于是我做了一個(gè)demo來(lái)定位問(wèn)題。

首先看父組件與子組件中各元素的初始值:


然后當(dāng)只改變父組件中數(shù)組的引用時(shí)可以看到子組件的props數(shù)組隨之改變,而子組件中綁定的數(shù)組確并沒(méi)有隨之改變


因此,可以發(fā)現(xiàn),問(wèn)題是出在了這一步

props: ['tableData', 'pageInfo'],
data() {
 return {
  tData: this.tableData,
  page: this.pageInfo
 }
}

 

而要弄清楚問(wèn)題的根源,就得弄清楚vue文檔中深入響應(yīng)式原理。


"在Vue實(shí)例的data選項(xiàng)中,Vue將遍歷此對(duì)象所有的屬性,并使用Object.defineProperty把這些屬性全部轉(zhuǎn)為 getter/setter","每個(gè)組件實(shí)例都有相應(yīng)的 watcher 實(shí)例對(duì)象,它會(huì)在組件渲染的過(guò)程中把屬性記錄為依賴,之后當(dāng)依賴項(xiàng)的 setter 被調(diào)用時(shí),會(huì)通知 watcher 重新計(jì)算,從而致使它關(guān)聯(lián)的組件得以更新。"文檔中說(shuō)了這么一大堆,簡(jiǎn)單理解就是Vue將data選項(xiàng)中的vm.$data.a與DOM中的vm.a進(jìn)行了雙向綁定,即其中一個(gè)變化,另一個(gè)也會(huì)跟著變化。在Vue源碼中是由defineReactive$$1函數(shù)實(shí)現(xiàn)的:

但在子其中主要是利用了Object.defineProperty的get和set方法實(shí)現(xiàn)了雙向綁定。而在子組件中,pros數(shù)據(jù)和子組件的$data是通過(guò)如下方式聯(lián)系在一起的:

tData: this.tableData

 

查詢Vue源碼可知this.tableData與tData之間僅僅是賦值,即"="關(guān)系

而上述的initData函數(shù)是在組件構(gòu)建時(shí)候執(zhí)行的,因此只會(huì)在create時(shí)執(zhí)行一次。這也是為什么官方文檔中"作為初始值傳入"這一說(shuō)法,因?yàn)樗揪椭粫?huì)執(zhí)行一次。當(dāng)組件構(gòu)建完成后,this.tableData與tData就沒(méi)有半毛錢關(guān)系了,其中一個(gè)的變化并不會(huì)引起另一個(gè)變化。當(dāng)然,這種說(shuō)法并不準(zhǔn)確,因?yàn)樵谏衔闹?,我們?dòng)態(tài)改變父組件傳入的total,子組件也"隨之"改變,感覺(jué)就像是綁定在一起了啊,這又是怎么回事呢?

3.引用類型帶來(lái)的假象

當(dāng)然,我們還是要從官方文檔出發(fā)來(lái)解決這個(gè)問(wèn)題。文檔中有這樣一個(gè)提示:


這里就需要理解引用類型的概念,引用數(shù)據(jù)類型值指保存在堆內(nèi)存中的對(duì)象。也就是,變量中保存的實(shí)際上的只是一個(gè)指針,這個(gè)指針指向內(nèi)存中的另一個(gè)位置,該位置保存著對(duì)象。訪問(wèn)方式是按引用訪問(wèn)。例如一個(gè)js對(duì)象a,他在內(nèi)存中的存儲(chǔ)形式如下圖所示:

var a = new Object();

 


當(dāng)操作時(shí),需要先從棧中讀取內(nèi)存地址,然后再延指針找到保存在堆內(nèi)存中的值再操作。

a.name = 'xz';

 


引用類型變量賦值,本質(zhì)上賦值的是存儲(chǔ)在棧中的指針,將指針復(fù)制到棧中未新變量分配的空間中,而這個(gè)指針副本和原指針指向存儲(chǔ)在堆中的同一個(gè)對(duì)象;賦值操作結(jié)束后,兩個(gè)變量實(shí)際上將引用同一個(gè)對(duì)象。因此,在使用時(shí),改變其中的一個(gè)變量的值,將影響另一個(gè)變量。

var b = a;

 


在了解了引用類型之后,我們?cè)趤?lái)看看上文提到的動(dòng)態(tài)改變傳入子組件前后內(nèi)存中的情況:

me.tableData = Json.data.restrictioninfo;
me.pageInfo.total = Json.data.total;
========================================
props: ['tableData', 'pageInfo'],
data() {
 return {
  tData: this.tableData,
  page: this.pageInfo
 }
}

 

首先對(duì)tableData的改變是改變了其引用的指針,而對(duì)pageInfo則改變了其中一個(gè)屬性的值,因此動(dòng)態(tài)改變前:


動(dòng)態(tài)改變后:


這樣就解釋了為什么子組件頁(yè)面的總數(shù)更新了,但table數(shù)據(jù)依然是初始化時(shí)的空數(shù)組。因?yàn)橐妙愋偷拇嬖?,我們?dòng)態(tài)改變父組件傳入的total,子組件也"隨之"改變了。

相關(guān)文章

  • Pinia進(jìn)階setup函數(shù)式寫(xiě)法封裝到企業(yè)項(xiàng)目

    Pinia進(jìn)階setup函數(shù)式寫(xiě)法封裝到企業(yè)項(xiàng)目

    這篇文章主要為大家介紹了Pinia進(jìn)階setup函數(shù)式寫(xiě)法封裝到企業(yè)項(xiàng)目實(shí)例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-07-07
  • vue項(xiàng)目中字符串換行顯示方式(返回的數(shù)據(jù)包含‘\r\n’字符)

    vue項(xiàng)目中字符串換行顯示方式(返回的數(shù)據(jù)包含‘\r\n’字符)

    這篇文章主要介紹了vue項(xiàng)目中字符串換行顯示方式(返回的數(shù)據(jù)包含‘\r\n’字符),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-04-04
  • Vue實(shí)現(xiàn)雙向滑動(dòng)輸入條

    Vue實(shí)現(xiàn)雙向滑動(dòng)輸入條

    這篇文章主要為大家詳細(xì)介紹了Vue實(shí)現(xiàn)雙向滑動(dòng)輸入條,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • 解決vue 局部過(guò)濾器獲取不到this的問(wèn)題

    解決vue 局部過(guò)濾器獲取不到this的問(wèn)題

    這篇文章主要介紹了解決vue 局部過(guò)濾器獲取不到this的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-01-01
  • vue3常用的指令之v-bind和v-on指令用法

    vue3常用的指令之v-bind和v-on指令用法

    vue的v-on與v-bind,v-on就是用于綁定事件的,下面這篇文章主要給大家介紹了關(guān)于vue3常用的指令之v-bind和v-on指令用法的相關(guān)資料,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-12-12
  • Vue之組件的自定義事件詳解

    Vue之組件的自定義事件詳解

    這篇文章主要為大家介紹了Vue之組件的自定義事件,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來(lái)幫助
    2021-11-11
  • 詳解vue過(guò)度效果與動(dòng)畫(huà)transition使用示例

    詳解vue過(guò)度效果與動(dòng)畫(huà)transition使用示例

    Vue 在插入、更新或者移除 DOM 時(shí),提供多種不同方式的應(yīng)用過(guò)渡效果,Vue 提供了內(nèi)置的過(guò)渡封裝組件transition,該組件用于包裹要實(shí)現(xiàn)過(guò)渡效果的組件
    2021-10-10
  • vue中使用 pinia 全局狀態(tài)管理的實(shí)現(xiàn)

    vue中使用 pinia 全局狀態(tài)管理的實(shí)現(xiàn)

    本文主要介紹了vue中使用 pinia 全局狀態(tài)管理的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2022-07-07
  • Vue 搭建Vuex環(huán)境詳解

    Vue 搭建Vuex環(huán)境詳解

    這篇文章主要為大家介紹了Vue搭建Vuex環(huán)境,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來(lái)幫助
    2021-11-11
  • Vue中引入第三方JS庫(kù)的四種方式

    Vue中引入第三方JS庫(kù)的四種方式

    在開(kāi)發(fā)Vue項(xiàng)目的時(shí)候,有時(shí)需要使用一些非ES6格式的沒(méi)有export的js庫(kù),下面這篇文章主要給大家介紹了關(guān)于Vue中引入第三方JS庫(kù)的詳細(xì)步驟,需要的朋友可以參考下
    2022-04-04

最新評(píng)論