日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

如何在Vue 3中擴(kuò)展Vue Router鏈接詳解

瀏覽:180日期:2022-09-28 14:59:58
前言

<router-link> 標(biāo)簽是一個(gè)很好的工具,可以在你的Vue應(yīng)用程序的不同頁(yè)面之間進(jìn)行導(dǎo)航,但當(dāng)導(dǎo)航到一個(gè)外部鏈接時(shí),它不是一個(gè)工具,為此,你應(yīng)該使用一個(gè)普通的<a> 標(biāo)簽。也許這只是我的問(wèn)題,但很多時(shí)候,我都懶得去理會(huì)這其中的差別。其他時(shí)候,鏈接可能是動(dòng)態(tài)的,也就是說(shuō),來(lái)自數(shù)據(jù)庫(kù)或一些用戶提供的數(shù)據(jù)源。在這種情況下,你根本不知道這個(gè)鏈接是外部的還是內(nèi)部的,而且在每個(gè)可能使用這個(gè)鏈接的地方手動(dòng)做V-if是多么痛苦的事情。

如果只是用一個(gè)單一的組件來(lái)處理所有的內(nèi)部和外部鏈接,那不是很好嗎?如果你和我一樣,你現(xiàn)在就會(huì)這樣做。

值得慶幸的是,擴(kuò)展<router-link> 組件是非常簡(jiǎn)單的,只需將其包裝在你自己的自定義組件中。讓我們開(kāi)始吧!讓我們建立一個(gè)AppLink 組件,它可以處理任何鏈接,無(wú)論是外部還是內(nèi)部。

AppLink組件

我們應(yīng)該做的第一件事是讓我們的AppLink組件接受所有與路由器鏈接相同的道具。為什么?這樣我們的組件的 '接口 '就可以模仿Router Link的接口,我們就不會(huì)有另一個(gè)API需要記住。我們可以通過(guò)從Vue Router中導(dǎo)入RouterLink,并將它的props分散到我們組件的props選項(xiàng)中來(lái)實(shí)現(xiàn)。

// AppLink.vue<script>import {RouterLink} from ’vue-router’export default{ props:{ ...RouterLink.props }}</script>

在模板區(qū),我們現(xiàn)在可以創(chuàng)建一個(gè)路由器鏈接標(biāo)簽,并將我們組件的所有道具綁定到它。我們還需要傳入插槽,以便標(biāo)簽之間提供的文本和標(biāo)記將出現(xiàn)在路由器鏈接中。

// AppLink.vue<template> <router-link v-bind='$props'><slot /></router-link></template>

就像現(xiàn)在這樣,我們已經(jīng)處理了所有的內(nèi)部鏈接。那么,外部鏈接呢?如前所述,外部鏈接使用a 標(biāo)簽,所以讓我們把它添加到我們的模板中。像路由器鏈接一樣,我們應(yīng)該傳遞槽。讓我們也把href 綁定到to 屬性。

// AppLink.vue<template> <a :href='http://www.b3g6.com/bcjs/to' rel='external nofollow' rel='external nofollow' ><slot/></a> <router-link v-bind='$props'><slot/></router-link></template>

酷,這就說(shuō)明了內(nèi)部鏈接和外部鏈接!在這一點(diǎn)上,可能值得注意的是,上述方法只適用于Vue 3,因?yàn)樗顺^(guò)1個(gè)根元素)。

現(xiàn)在,我們只需要一個(gè)條件來(lái)告訴我們提供給AppLink的是什么類型的鏈接。我們可以創(chuàng)建一個(gè)名為isExternal 的計(jì)算屬性來(lái)確定這一點(diǎn)。首先,我們要檢查我們的to道具的值是否是一個(gè)字符串。這是必要的,因?yàn)閠o 道具可能是一個(gè)對(duì)象,比如有時(shí)傳遞給router-link (即:to='{name:’RouteNameHere’}' )。然后,我們將檢查該字符串是否以http 的字符串開(kāi)始。如果這兩個(gè)條件都是真的,那么我們就有了自己的一個(gè)外部鏈接。

// AppLink.vue<script>export default{ //... computed:{ isExternal(){ return typeof this.to === ’string’ && this.to.startsWith(’http’) } }}</script>

router-link在模板區(qū),我們現(xiàn)在可以在一個(gè)v-if中使用isExternal 計(jì)算的道具,當(dāng)它是a ,否則就顯示true 。

// AppLink.vue<template> <a v-if='isExternal' :href='http://www.b3g6.com/bcjs/to' rel='external nofollow' rel='external nofollow' ><slot/></a> <router-link v-else v-bind='$props'><slot/></router-link></template>

就這樣了!我們完成了!在你的應(yīng)用程序中全局注冊(cè)該組件后,你現(xiàn)在可以像這樣使用它。

// Anywhere in your app<AppLink :to='[external-or-internal-link]'>Click Me</AppLink>

如何在Vue 3中擴(kuò)展Vue Router鏈接詳解

進(jìn)一步的靈活性

在新標(biāo)簽頁(yè)中打開(kāi)

讓我們把AppLink 組件變得更加有用。比方說(shuō),我們希望所有的外部鏈接總是在新的標(biāo)簽頁(yè)中打開(kāi)。很簡(jiǎn)單。只要在組件中的<a> 標(biāo)簽上添加一個(gè)target='_blank' ,整個(gè)網(wǎng)站的所有外部鏈接現(xiàn)在都在新標(biāo)簽中打開(kāi)。

// AppLink.vue<template> <a ... target='_blank'><slot/></a> ...</template>

這是你可能希望適用于你網(wǎng)站上大多數(shù)外部鏈接的規(guī)則,但如果你希望任何特定的外部鏈接在同一標(biāo)簽中打開(kāi),你可以用html目標(biāo)屬性告訴該鏈接實(shí)例這樣做。

<AppLink :to='https://vueschool.io' target='_self'>Vue School</AppLink>

鏈接安全

當(dāng)你使用target='_blank' 屬性鏈接到另一個(gè)網(wǎng)站上的一個(gè)頁(yè)面時(shí),你最終會(huì)使你的網(wǎng)站暴露在性能和安全問(wèn)題中。

被鏈接的頁(yè)面可能最終與你的頁(yè)面在同一進(jìn)程中運(yùn)行。根據(jù)被鏈接頁(yè)面的情況,這可能會(huì)降低你自己頁(yè)面的速度。 另一個(gè)頁(yè)面也可以通過(guò)window.opener 屬性訪問(wèn)原始頁(yè)面window ,造成安全問(wèn)題。

關(guān)于這個(gè)問(wèn)題的更多細(xì)節(jié),請(qǐng)看這個(gè)信息性的帖子。

解決這個(gè)問(wèn)題的辦法是為你所有的外部鏈接標(biāo)簽提供一個(gè)rel='noopener' 屬性。但要記住這樣做是多么痛苦啊......哦,等等......我們不需要這樣做。我們可以在我們的AppLink 組件中添加一次,就可以了。

// AppLink.vue<template> <a ... rel='noopener'><slot/></a> ...</template>

外部鏈接的獨(dú)特風(fēng)格

我看到一些網(wǎng)站在其網(wǎng)站上的外部鏈接的樣式與通往他們自己網(wǎng)站上其他地方的鏈接有點(diǎn)不同。這可以幫助用戶更好地了解他們是如何在一個(gè)他們?cè)緵](méi)有訪問(wèn)過(guò)的網(wǎng)站上結(jié)束的。它可以是任何東西,從鏈接旁邊的一個(gè)微妙的 '外部鏈接 '圖標(biāo)到鏈接下面的一個(gè)小警告,比如說(shuō) '鏈接到第三方網(wǎng)站'。在我們的組件中實(shí)現(xiàn)這一點(diǎn)很簡(jiǎn)單,只要在我們的模板中的a 標(biāo)簽上添加一個(gè)external-link 類,然后用css來(lái)改變它的風(fēng)格,或者添加一個(gè):after sudo-element。你甚至可以為外部鏈接添加全新的元素,比如一個(gè)字體超贊的圖標(biāo)。

// AppLink.vue// (must have font awesome font included in project)<template> <a ... class='external-link'> <slot/> <i class='fas fa-external-link-alt'></i> </a> ...</template><style scoped>.external-link i { font-size: 0.8em; opacity: 0.7;}</style>總結(jié)

這只是你可以擴(kuò)展router-link以適應(yīng)常見(jiàn)和特殊情況下的需求的一個(gè)嘗試。另外,由于你的所有鏈接都被封裝在一個(gè)單一的組件中,你可以很容易地更新你所有鏈接的不同方面。你能想到任何其他有用的方法來(lái)改進(jìn)我們的AppLink 組件嗎?你是否在你的應(yīng)用程序中使用類似的方法,并有一些智慧可以分享?

到此這篇關(guān)于如何在Vue 3中擴(kuò)展Vue Router鏈接的文章就介紹到這了,更多相關(guān)Vue3擴(kuò)展Vue Router鏈接內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: Vue
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
欧美欧美黄在线二区| 红桃视频欧美| 亲子伦视频一区二区三区| 国产欧美啪啪| 欧美成人精品午夜一区二区| 欧美福利在线| 亚洲精品乱码| 国产精品videossex久久发布| 久久精品av麻豆的观看方式| 亚洲网址在线观看| 国产精品免费大片| 欧美日韩视频免费观看| 亚洲网站视频| 日本久久精品| 国产精品毛片| 色爱综合av| 亚洲无线一线二线三线区别av| 精品精品99| 欧美国产极品| 国产免费成人| se01亚洲视频 | 欧美aa在线观看| 日韩高清成人在线| 亚洲精品一区二区妖精| 国产欧美三级| 国产麻豆精品| 久久精品色播| 欧美一区二区三区高清视频| 午夜久久久久| 亚洲aa在线| av在线日韩| 日本少妇一区二区| 欧美1区2区3区| 久久久久久婷| 欧美一区自拍| 另类av一区二区| 国产美女高潮在线| 日韩国产在线观看一区| 久久97久久97精品免视看秋霞| 91看片一区| 国产欧美日韩精品一区二区三区| 视频二区不卡| 美女高潮久久久| 免费人成网站在线观看欧美高清| 国产日韩在线观看视频| 国内激情久久| 日韩免费视频| 激情综合激情| 蜜桃视频一区二区三区| 动漫av一区| 国产精品一区二区精品视频观看| 欧美精品高清| 精品一区电影| 麻豆精品蜜桃视频网站| 中文精品视频| 91精品国产成人观看| 婷婷久久免费视频| 亚洲国产专区| 国产亚洲精品美女久久| 欧洲一区二区三区精品| 久久不见久久见免费视频7| 精品在线99| 亚洲大全视频| 91成人超碰| 日本欧美在线看| 日韩中文字幕不卡| 香蕉久久久久久| 日韩不卡在线观看日韩不卡视频| 国产视频一区欧美| 首页欧美精品中文字幕| 精品91久久久久| 麻豆精品91| 日韩精品中文字幕吗一区二区| 欧美日韩一二三四| 99成人超碰| 亚洲精品91| 亚洲三级欧美| 欧美国产91| 亚洲精品一区二区妖精| 999视频精品| 视频一区视频二区中文| 蜜臀久久99精品久久久画质超高清| 亚洲中字黄色| 国产免费av一区二区三区| 日本va欧美va精品发布| 日韩欧美中文字幕电影| 欧美专区一区| 精品不卡一区| 九一成人免费视频| 亚洲专区欧美专区| 日韩激情av在线| 97精品国产| 中文字幕亚洲精品乱码| 久久97视频| 综合国产精品| 蜜桃精品在线| 国产日韩欧美一区| 在线亚洲观看| 黄毛片在线观看| 欧美天堂一区| 亚洲一区区二区| 福利一区二区三区视频在线观看| 91精品国产福利在线观看麻豆| 日韩中文字幕区一区有砖一区 | 欧美福利一区| 你懂的国产精品| 先锋影音国产一区| 91精品国产成人观看| 日韩国产一二三区| 婷婷丁香综合| 国产aa精品| 国产欧美日韩精品一区二区三区| 日韩成人精品一区| 日韩在线黄色| 蘑菇福利视频一区播放| 国产91在线精品| 国产精品嫩模av在线| 性色一区二区| 亚洲黄色在线| 狠狠色狠狠色综合日日tαg| 国产精品网在线观看| 日韩精品一级中文字幕精品视频免费观看| 中文字幕色婷婷在线视频| 日韩不卡手机在线v区| 亚洲欧美视频一区二区三区| 久久精品日韩欧美| 国产精品久久久久77777丨| 久久中文视频| 私拍精品福利视频在线一区| 欧美1区免费| 日韩欧美高清一区二区三区| 精品久久电影| 国产一区一一区高清不卡| 欧美日韩一区二区国产| 久久福利精品| 亚洲精品婷婷| 国产精品久久久免费| 国产欧美一区| 精品国产鲁一鲁****| 粉嫩av一区二区三区四区五区| 国产精品极品国产中出| 国产精品对白| 狂野欧美性猛交xxxx| 国产精品一区二区精品视频观看| 日本视频一区二区| 久久字幕精品一区| 成人久久一区| 中文字幕中文字幕精品| 97精品久久| 狠狠躁少妇一区二区三区| 亚洲成人一区在线观看| 欧美久久精品一级c片| 亚洲制服欧美另类| 国内在线观看一区二区三区| 国产精品v日韩精品v欧美精品网站| 麻豆精品99| 免播放器亚洲| 国产极品嫩模在线观看91精品| 美女国产精品久久久| 99精品视频精品精品视频| 另类亚洲自拍| 国产精品yjizz视频网| 国产精品毛片| 国产aa精品| 亚洲精品麻豆| 欧美日韩国产在线一区| 国产欧美一区二区三区精品观看| 色爱综合网欧美| 亚洲精品乱码久久久久久蜜桃麻豆 | 久久国产精品美女| 播放一区二区| 国产精品66| 香蕉久久久久久久av网站| 欧美精品aa| 亚洲aa在线| 日本欧美在线看| 尤物在线精品| 亚洲我射av| 成人在线丰满少妇av| 日韩精品一二三区| 妖精视频成人观看www| 91成人在线网站| 免费观看日韩电影| 久久婷婷av| 日韩激情一区| 国产成人精品一区二区免费看京| 亚洲精品在线二区| 亚洲免费影院| 尤物网精品视频| 午夜免费一区| 婷婷丁香综合| 亚洲欧美成人综合| 国产视频一区免费看| 久久久国产亚洲精品| 精品三级在线| 丁香婷婷久久| 国产精品丝袜在线播放| 婷婷亚洲成人| 日韩精品社区| 国产精品片aa在线观看 |