vue中的自定義屬性并獲得屬性的值方式
自定義屬性并獲得屬性的值
例如
data-radius語法: data-屬性
vue:
<div @mouseover='changeRadius($event)' @mouseout='changeRadius(false)' @click='setlocation($event)'> ? ? ? ? ? <div data-radius='100'>100m</div> ? ? ? ? ? <div data-radius='300'>300m</div> ? ? ? ? ? <div data-radius='500'>500m</div> ? ? ? ? ? <div data-radius='1000'>1000m</div> </div>
獲取屬性的值:ev.target.dataset.radius
methods:
setlocation:function(ev){ ? ? this.dispradius = ev.target.dataset.radius + '米' }
對自定義屬性--props的理解
由于最近學(xué)習(xí)完vue在做項(xiàng)目,但是在跟做項(xiàng)目時,發(fā)現(xiàn)一個問題就是props自定義屬性出現(xiàn)了可以讀也可以寫,并且數(shù)據(jù)流向成了雙向的問題。
初始props
在剛剛學(xué)習(xí)的時候,對于props的了解是只能讀不能寫,并且同時它還是作為組件之間值傳遞的工具,父組件對子組件單向數(shù)據(jù)流動
問題的出現(xiàn)
此處放代碼:
在頁面中用vue去查數(shù)據(jù)的確發(fā)生了數(shù)據(jù)的更改
但是在跟做別人的項(xiàng)目時,發(fā)現(xiàn)父組件和子組件中數(shù)據(jù)出現(xiàn)了雙向流動,并且eslint規(guī)范報(bào)了錯誤,今天查閱props文檔的時候,原文如下:
所有的 prop 都使得其父子 prop 之間形成了一個單向下行綁定:父級 prop 的更新會向下流動到子組件中,但是反過來則不行。這樣會防止從子組件意外變更父級組件的狀態(tài),從而導(dǎo)致你的應(yīng)用的數(shù)據(jù)流向難以理解。
發(fā)現(xiàn)props數(shù)據(jù)單向流動并不是固定死的,它是通常情況下都是單向流動,但是它在數(shù)據(jù)為對象和數(shù)組時,是可以發(fā)生雙向流動
為什么會發(fā)生雙向流動的問題?
原因:注意在 JavaScript 中對象和數(shù)組是通過引用傳入的,所以對于一個數(shù)組或?qū)ο箢愋偷?prop 來說,在子組件中改變變更這個對象或數(shù)組本身將會影響到父組件的狀態(tài)。
總結(jié):
1、為了規(guī)范自己的代碼書寫,以后將保證當(dāng)要這個 prop 用來傳遞一個初始值;這個子組件接下來希望將其作為一個本地的 prop 數(shù)據(jù)來使用時,將其存儲到data數(shù)據(jù)中,data的數(shù)據(jù)是可讀寫的
2、對于雙向流動的問題,不去直接修改props的值,當(dāng)父組件在需要子組件的值時,再進(jìn)行子向父傳值(此處還有一個問題,隨后補(bǔ)充)
補(bǔ)充問題
前面說到props自定義屬性不能寫,其實(shí)是為了限制數(shù)據(jù)流向混亂,因此只讀不寫,所以這里數(shù)組和對象是可以寫的。
代碼證明:
this.tableData = this.tableData.filter((item, index) => index !== i) const id = this.tableData[i].id
但是最后為了規(guī)范,還是將數(shù)據(jù)存到了data,進(jìn)行了代碼修改。而且也出現(xiàn)了數(shù)據(jù)異步的問題(已經(jīng)解決在后面的文章)。
以上為個人經(jīng)驗(yàn),希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
vue中同時監(jiān)聽多個參數(shù)的實(shí)現(xiàn)
這篇文章主要介紹了vue中同時監(jiān)聽多個參數(shù)的實(shí)現(xiàn)方式,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-04-04vue2.0 實(shí)現(xiàn)導(dǎo)航守衛(wèi)的具體用法(路由守衛(wèi))
這篇文章主要介紹了vue2.0 實(shí)現(xiàn)導(dǎo)航守衛(wèi)的具體用法(路由守衛(wèi)),vue-route 提供的 beforeRouteUpdate 可以方便地實(shí)現(xiàn)導(dǎo)航守衛(wèi)(navigation-guards),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-05-05Vue中的el-date-picker時間選擇器的使用實(shí)例詳解
el-date-picker是Element UI框架中提供的日期選擇器組件,它支持單個日期、日期范圍、時間、日期時間等多種選擇方式,本文給大家介紹Vue中的el-date-picker時間選擇器的使用,感興趣的朋友一起看看吧2023-10-10vue+vuex+json-seiver實(shí)現(xiàn)數(shù)據(jù)展示+分頁功能
這篇文章主要介紹了vue+vuex+json-seiver實(shí)現(xiàn)數(shù)據(jù)展示+分頁功能,非常不錯,具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-04-04使用vue-cli webpack 快速搭建項(xiàng)目的代碼
這篇文章主要介紹了vue-cli webpack 快速搭建項(xiàng)目的教程詳解,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2018-11-11vue中v-text / v-html使用實(shí)例代碼詳解
這篇文章主要介紹了vue中v-text / v-html使用實(shí)例代碼詳解,非常不錯,代碼簡單易懂,具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-04-04