解決Vue 刷新頁面導(dǎo)航顯示高亮位置不對問題
首先:現(xiàn)在是我點擊在產(chǎn)品介紹頁面

但是當我刷新頁面后高亮位置就變成了第一個


在頭部組件里面控制導(dǎo)航高亮顯示是checked,默認值是0,觸發(fā)點擊事件會重新賦值,跳轉(zhuǎn)路由,當刷新頁面,checked值是0,所以要監(jiān)聽checked時刻發(fā)生變化;利用到vue的父子和子父傳值;監(jiān)聽狀態(tài)的變化
子頁面將值傳給父頁面

父頁面接收傳過來的值

父組件把值傳給header頭部組件,頭部組件通過prop接收

所有的 prop 都使得其父子 prop 之間形成了一個單向下行綁定:父級 prop 的更新會向下流動到子組件中,但是反過來則不行。這樣會防止從子組件意外改變父級組件的狀態(tài),從而導(dǎo)致你的應(yīng)用的數(shù)據(jù)流向難以理解。
額外的,每次父級組件發(fā)生更新時,子組件中所有的 prop 都將會刷新為最新的值。這意味著你不應(yīng)該在一個子組件內(nèi)部改變 prop。如果你這樣做了,Vue 會在瀏覽器的控制臺中發(fā)出警告。
這里有兩種常見的試圖改變一個 prop 的情形:
1.這個 prop 用來傳遞一個初始值;這個子組件接下來希望將其作為一個本地的 prop 數(shù)據(jù)來使用。在這種情況下,
最好定義一個本地的 data 屬性并將這個 prop 用作其初始值:
props: ['initialCounter'],
data: function () {
return {
counter: this.initialCounter
}
}
2.這個 prop 以一種原始的值傳入且需要進行轉(zhuǎn)換。在這種情況下,最好使用這個 prop 的值來定義一個計算屬性:
props: ['size'],
computed: {
normalizedSize: function () {
return this.size.trim().toLowerCase()
}
}
這里我用的是第二種:

以上就是解決了頁數(shù)刷新高亮顯示錯誤的辦法了 存下
總結(jié)
以上所述是小編給大家介紹的解決Vue 刷新頁面導(dǎo)航顯示高亮位置不對問題,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉(zhuǎn)載,煩請注明出處,謝謝!
相關(guān)文章
vue中element 的upload組件發(fā)送請求給后端操作
這篇文章主要介紹了vue中element 的upload組件發(fā)送請求給后端操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-09-09
Vue?vant-ui使用van-uploader實現(xiàn)頭像上傳功能
這篇文章主要介紹了Vue?vant-ui使用van-uploader實現(xiàn)頭像圖片上傳,項目中是使用有贊vant-ui框架實現(xiàn)的頭像上傳替換功能,用到了封裝的圖片壓縮封裝之后再去上傳圖片this.$imgUpload.imgZip(),本文通過實例代碼給大家介紹的非常詳細,需要的朋友參考下吧2022-05-05
VSCode寫vue項目一鍵生成.vue模版,修改定義其他模板的方法
這篇文章主要介紹了VSCode寫vue項目一鍵生成.vue模版,修改定義其他模板的方法,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-04-04

