欧美一区二区三区老妇人-欧美做爰猛烈大尺度电-99久久夜色精品国产亚洲a-亚洲福利视频一区二区

vue.js中怎么利用props傳遞參數(shù)

vue.js中怎么利用props傳遞參數(shù),針對這個(gè)問題,這篇文章詳細(xì)介紹了相對應(yīng)的分析和解答,希望可以幫助更多想解決這個(gè)問題的小伙伴找到更簡單易行的方法。

創(chuàng)新互聯(lián)是一家專注于成都網(wǎng)站設(shè)計(jì)、做網(wǎng)站與策劃設(shè)計(jì),遼寧網(wǎng)站建設(shè)哪家好?創(chuàng)新互聯(lián)做網(wǎng)站,專注于網(wǎng)站建設(shè)十多年,網(wǎng)設(shè)計(jì)領(lǐng)域的專業(yè)建站公司;建站業(yè)務(wù)涵蓋:遼寧等地區(qū)。遼寧做網(wǎng)站價(jià)格咨詢:18982081108

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

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

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

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

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

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

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

然后根據(jù)官方文檔的說法,當(dāng)每次父組件更新時(shí),子組件的所有prop都會(huì)更新為最新值。而tableData和pageInfo的信息是異步通過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;

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

vue.js中怎么利用props傳遞參數(shù)

2.賦值與綁定

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

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

vue.js中怎么利用props傳遞參數(shù)

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

vue.js中怎么利用props傳遞參數(shù)

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

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

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

vue.js中怎么利用props傳遞參數(shù)

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

vue.js中怎么利用props傳遞參數(shù)

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

tData: this.tableData

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

vue.js中怎么利用props傳遞參數(shù)

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

3.引用類型帶來的假象

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

vue.js中怎么利用props傳遞參數(shù)

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

var a = new Object();

vue.js中怎么利用props傳遞參數(shù)

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

a.name = 'xz';

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

var b = a;

vue.js中怎么利用props傳遞參數(shù)
在了解了引用類型之后,我們在來看看上文提到的動(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
 }
}

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

vue.js中怎么利用props傳遞參數(shù)

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

vue.js中怎么利用props傳遞參數(shù)

關(guān)于vue.js中怎么利用props傳遞參數(shù)問題的解答就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道了解更多相關(guān)知識。

分享標(biāo)題:vue.js中怎么利用props傳遞參數(shù)
本文地址:http://chinadenli.net/article48/gshhep.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供App開發(fā)虛擬主機(jī)網(wǎng)站制作網(wǎng)站策劃靜態(tài)網(wǎng)站定制開發(fā)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

成都做網(wǎng)站