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

vue路由 遍歷生成復(fù)數(shù)router-link的例子

 更新時(shí)間:2019年10月30日 11:24:23   作者:qwezxc24680  
今天小編就為大家分享一篇vue路由 遍歷生成復(fù)數(shù)router-link的例子,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧

業(yè)務(wù)場(chǎng)景:使用vue-cli做一個(gè)spa;

需求:頂部導(dǎo)航欄控制下方內(nèi)容欄,實(shí)現(xiàn)頁(yè)面內(nèi)切換。

毫無(wú)疑問(wèn),vue-router很適合這樣的需求,實(shí)現(xiàn)起來(lái)也并不復(fù)雜:

1、main.js:

import VueRouter from 'vue-router'
Vue.use(VueRouter);

2、定義(路由)組件:

import songList from './components/songList.vue'
 
const Bar = { template: '<div>no.2</div>' }
const Baz = { template: '<div>no.3</div>' }
const Fun = { template: '<div>no.4</div>' }

這里的組件也可以從外部導(dǎo)入,說(shuō)起來(lái)應(yīng)該是正確的做法,博主為了演示方便才直接寫(xiě)在里面了...

3、定義路由:

const routes = [
 { path: '/新歌',
 component: songList
 },
 { path: '/排行',
 component: Bar
 },
 { path: '/榜單',
 component: Baz
 },
 { path: '/歌手',
 component: Fun
 },
 { path: '*',
 redirect: '/新歌'
 }
]

注意,最后設(shè)置了一個(gè)重定向路由,目的是當(dāng)路徑不屬于以上任意一個(gè)時(shí),匹配到‘新歌'頁(yè)面;說(shuō)白了也就是設(shè)置初始頁(yè)的路由。

4、創(chuàng)建router實(shí)例:

const router = new VueRouter({
 routes//等價(jià)routes: routes
})

5、創(chuàng)建和掛載根實(shí)例:

new Vue({
 router,
 el: '#app',
 render: h => h(App)
})

navBar.vue:

在組件頁(yè)面上,按照常理應(yīng)該分別寫(xiě)出具體數(shù)目的導(dǎo)航標(biāo)簽,類似下面這樣:

<router-link to="/新歌">新歌</router-link>
<router-link to="/排行">排行</router-link>
<router-link to="/榜單">榜單</router-link>
<router-link to="/歌手">歌手</router-link>

但實(shí)際運(yùn)用上有個(gè)小問(wèn)題,就是像這樣重復(fù)樣式的路由入口真的有必要每個(gè)都寫(xiě)一遍么?唯一的區(qū)別僅僅是to屬性不同?

萬(wàn)一今后碰到十幾、二十個(gè)怎么辦?

于是換個(gè)思路,嘗試遍歷數(shù)組來(lái)生成復(fù)數(shù)個(gè)路由入口:

<span v-for="(bar, index) in title" :key="index">
 <router-link to="">
 {{ bar }}
 </router-link>
</span>

大致如上,title是一個(gè)所有名目的數(shù)組:[ 新歌,排行,榜單,歌手,... ],Index索引用來(lái)綁定key值?,F(xiàn)在唯一的問(wèn)題 就是to也就是路由入口路徑該怎么寫(xiě)?

由于每個(gè)都會(huì)渲染成不同出口,所以不能寫(xiě)成絕對(duì)路徑。

方案一:將main.js中的路徑都變成title中的名稱,再在to中用拼接字符串實(shí)現(xiàn)動(dòng)態(tài)匹配。

實(shí)際操作下來(lái)發(fā)現(xiàn)并不可取,因?yàn)樵趆tml中只會(huì)識(shí)別to=“”中雙引號(hào)內(nèi)的內(nèi)容,更不能使用‘+'這類js才能識(shí)別的拼接符號(hào)。

方案二:使用編程式導(dǎo)航,

methods: {
 linkChange: function (bar) {
  this.$router.push({ path: '/'+bar});
 }
 }

<span v-for="(bar, index) in title" :key="index">
 <router-link to="" @click.native="linkChange(bar)">
 {{ bar }}
 </router-link>
</span>

這種方法將路徑寫(xiě)在methods中就可以使用每次遍歷數(shù)組獲得的值,從而實(shí)現(xiàn)動(dòng)態(tài)匹配。

為什么要給click事件加上native后綴?

這里是個(gè)很典型的router-link的小坑,因?yàn)闉g覽器會(huì)把router-link渲染成a標(biāo)簽,那么在router-link上添加的事件都會(huì)失效。

解決方案就是加上.native后綴來(lái)阻止原生事件。

但這種方式也有個(gè)很嚴(yán)重的BUG,即在遍歷中使用編程式導(dǎo)航,會(huì)導(dǎo)致所有入口響應(yīng)這個(gè)點(diǎn)擊事件!

具體說(shuō)來(lái)就是當(dāng)用戶點(diǎn)擊某個(gè)路由,所有的入口都會(huì)被vue識(shí)別為選中路由,頁(yè)面邏輯可能看不出來(lái),

但只要加個(gè).router-link-active { background: #f4f4f4 }這種vue給當(dāng)前路由默認(rèn)添加的class設(shè)置一個(gè)背景色,就能發(fā)現(xiàn)所有路由入口元素

一起變色!

這個(gè)bug在不使用遍歷,依次給span設(shè)置路由的時(shí)候不會(huì)出現(xiàn),具體原因希望有大神可以告知。

所以此方案也只能放棄。

方案三:

在html中綁定to屬性,

<span v-for="(bar, index) in title" :key="index">
 <router-link :to="{ path: '/'+bar }">
 {{ bar }}
 </router-link>
</span>

想了太多復(fù)雜的方案,反而忽略了最基本的綁定to屬性,

最方便的地方在于,大括號(hào)內(nèi)既可以像我一樣寫(xiě)完整路徑,也可以直接寫(xiě)成:to="{ path: bar }",效果是一樣的。

而且相比前面的方法,可以省去額外的點(diǎn)擊事件,利用其本身的路徑特性來(lái)完成。

到目前為止,需求可以算是基本完成,但細(xì)節(jié)還能不能更完美一點(diǎn)呢?

就拿這個(gè)例子來(lái)說(shuō),我們用span標(biāo)簽包裹了渲染成a標(biāo)簽的router-link,有時(shí)候我們想要選中的標(biāo)簽字體變成藍(lán)色,同時(shí)span下面出現(xiàn)藍(lán)色邊框,

提高用戶體驗(yàn)。那么使用.router-link-active改變a標(biāo)簽顏色是最方便的了,問(wèn)題是上一級(jí)的span該如何添加樣式呢?

似乎不添加額外class或id這種標(biāo)識(shí)是無(wú)法實(shí)現(xiàn)功能的,但我在vue官網(wǎng)上看到這么一句話:“有時(shí)候我們要讓 "激活時(shí)的CSS類名" 應(yīng)用在外層元素,而不是 <a> 標(biāo)簽本身,那么可以用 <router-link> 渲染外層元素,包裹著內(nèi)層的原生 <a> 標(biāo)簽”。

代碼如下:

<router-link tag="span" :to="{ path: bar }" v-for="(bar, index) in title" :key="index">
  <a>
  {{ bar }}
  </a>
 </router-link>

使用tag標(biāo)簽改變其渲染元素,包裹a標(biāo)簽。如此一來(lái),.router-link-active添加span底邊框,.router-link-active a 來(lái)改變字體顏色。

不需要使用額外標(biāo)記也能完成樣式需求。

以上這篇vue路由 遍歷生成復(fù)數(shù)router-link的例子就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • Vue實(shí)現(xiàn)項(xiàng)目部署到非根目錄及解決刷新頁(yè)面時(shí)找不到資源

    Vue實(shí)現(xiàn)項(xiàng)目部署到非根目錄及解決刷新頁(yè)面時(shí)找不到資源

    這篇文章主要介紹了Vue實(shí)現(xiàn)項(xiàng)目部署到非根目錄及解決刷新頁(yè)面時(shí)找不到資源問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • element?el-tree折疊收縮的實(shí)現(xiàn)示例

    element?el-tree折疊收縮的實(shí)現(xiàn)示例

    本文主要介紹了element?el-tree折疊收縮的實(shí)現(xiàn)示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2022-08-08
  • Vue Transition實(shí)現(xiàn)類原生組件跳轉(zhuǎn)過(guò)渡動(dòng)畫(huà)的示例

    Vue Transition實(shí)現(xiàn)類原生組件跳轉(zhuǎn)過(guò)渡動(dòng)畫(huà)的示例

    本篇文章主要介紹了Vue Transition實(shí)現(xiàn)類原生組件跳轉(zhuǎn)過(guò)渡動(dòng)畫(huà)的示例,具有一定的參考價(jià)值,有興趣的可以了解一下
    2017-08-08
  • vue3.0報(bào)錯(cuò)Cannot?find?module‘worker_threads‘的解決辦法

    vue3.0報(bào)錯(cuò)Cannot?find?module‘worker_threads‘的解決辦法

    這篇文章介紹了vue3.0報(bào)錯(cuò)Cannot?find?module‘worker_threads‘的解決辦法。對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2021-11-11
  • vue2和vue3子組件父組件之間的傳值方法

    vue2和vue3子組件父組件之間的傳值方法

    在組件化開(kāi)發(fā)的過(guò)程中難免會(huì)遇見(jiàn)子組件和父組件之間的通訊那么這里講關(guān)于vue2和vue3不同的通訊方式,文中有詳細(xì)的代碼示例供大家參考,感興趣的同學(xué)可以閱讀下
    2023-05-05
  • Vuex 使用及簡(jiǎn)單實(shí)例(計(jì)數(shù)器)

    Vuex 使用及簡(jiǎn)單實(shí)例(計(jì)數(shù)器)

    這篇文章主要介紹了Vuex 使用及簡(jiǎn)單實(shí)例(計(jì)數(shù)器),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-08-08
  • vue單頁(yè)開(kāi)發(fā)父子組件傳值思路詳解

    vue單頁(yè)開(kāi)發(fā)父子組件傳值思路詳解

    這篇文章主要介紹了vue單頁(yè)開(kāi)發(fā)父子組件傳值思路詳解,本文是小編抽空整理的思路,感興趣的朋友跟隨腳本之家小編一起學(xué)習(xí)吧
    2018-05-05
  • vue前端傳空值、空字符串的問(wèn)題及解決

    vue前端傳空值、空字符串的問(wèn)題及解決

    這篇文章主要介紹了vue前端傳空值、空字符串的問(wèn)題及解決,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-06-06
  • 詳解uniapp的生命周期

    詳解uniapp的生命周期

    這篇文章主要介紹了uniapp的生命周期,應(yīng)用生命周期是指應(yīng)用程序從啟動(dòng)到關(guān)閉的整個(gè)過(guò)程,包括應(yīng)用程序的啟動(dòng)、前后臺(tái)切換、退出等,需要的朋友可以參考下
    2023-04-04
  • vue引入靜態(tài)js文件的方法

    vue引入靜態(tài)js文件的方法

    這篇文章主要介紹了vue引入靜態(tài)js文件的方法,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-06-06

最新評(píng)論