Vue 中使用v-for語句拋出錯(cuò)誤的解決方案
今天在維護(hù)以前的項(xiàng)目的時(shí)候遇見了下面的報(bào)錯(cuò)情況,開始我以為是因?yàn)閖Query和Vue沖突了,所以把以前的jQuery改了,但是還是出現(xiàn)同樣的錯(cuò)誤…通過查閱資料,發(fā)現(xiàn)是因?yàn)檠h(huán)的變量里面的值重復(fù)了,導(dǎo)致Vue報(bào)錯(cuò)。
代碼如下:
Uncaught (in promise) TypeError: Cannot read property ‘removeChild' of null
接下來查了一下解決方案,發(fā)現(xiàn)在Vue 2.0之前的版本可以通過在v-for語句后面加如下語句解決:
<div v-for="item in items" track-by="id">
不過在Vue 2.0之后的版本中track-by改為了key,所以對于Vue 2.0之后的版本可以使用:
<div v-for="item in items" v-bind:key="item.id">
其實(shí),在查看API返回的JSON數(shù)據(jù)后,發(fā)現(xiàn)重復(fù)請求了接口,所以,這個(gè)問題本來就不應(yīng)該出現(xiàn)的。所以特意在接口獲取數(shù)據(jù)的地方加上了一個(gè)過濾方法:
self.goodsList.indexOf(arr) === -1 ? self.goodsList.push(arr) : undefined
這句語句就是說如果獲取的數(shù)組元素不重復(fù)的話,才將數(shù)組元素加入到列表中。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持錯(cuò)新站長站。
新聞熱點(diǎn)
疑難解答
圖片精選