欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Vue路由應(yīng)用詳細(xì)講解

 更新時(shí)間:2022年11月22日 16:22:24   作者:一桿老狙  
路由的本質(zhì)就是一種對(duì)應(yīng)關(guān)系,根據(jù)不同的URL請(qǐng)求,返回對(duì)應(yīng)不同的資源。那么url地址和真實(shí)的資源之間就有一種對(duì)應(yīng)的關(guān)系,就是路由

介紹

vue-router相當(dāng)于vue內(nèi)部跳轉(zhuǎn)鏈接,將需要切換的頁(yè)面在vue-router里注冊(cè),在項(xiàng)目里配置就能完成頁(yè)面的切換,它不僅能完成項(xiàng)目的切換,還能實(shí)現(xiàn)參數(shù)的傳遞,它還有個(gè)很重要的功能路由導(dǎo)航守衛(wèi)(導(dǎo)航守衛(wèi)分為前置導(dǎo)航守衛(wèi),后置導(dǎo)航守衛(wèi),組件內(nèi)置導(dǎo)航守衛(wèi),常用就是前置導(dǎo)航守衛(wèi),設(shè)置用戶(hù)登錄可訪問(wèn)的界面和未登錄可訪問(wèn)的界面,也相當(dāng)于二次攔截,(axios請(qǐng)求攔截器是第一次攔截))。

路由跳轉(zhuǎn)和傳參

重點(diǎn):

在vue-router中,有兩大對(duì)象被掛載到了實(shí)例this;

$route(只讀、具備信息的對(duì)象);

$router(具備功能的函數(shù));

1.router-link(類(lèi)似a標(biāo)簽)

路由配置:

// 路由配置
 {
   path: '/pkproperties', // 路徑
   name:'pkproperties', // 路由名,path路徑必寫(xiě),用name跳轉(zhuǎn)的時(shí)候是根據(jù)name名找到path進(jìn)行跳轉(zhuǎn)
   component: () => import('@/views/pkproperties'), // 組件(組件文件名為index的可省略),路由懶加載寫(xiě)法
   redirect: '', // 路由重定向,就是當(dāng)一個(gè)頁(yè)面需要切換多個(gè)路由的時(shí)候,這里面填的是首次進(jìn)入頁(yè)面展示的路由組件地址
   hidden: true,
   children: [] // 嵌套路由,當(dāng)一頁(yè)有很多路由需要切換的時(shí)候,就需要用到嵌套路由
  },
// 組件內(nèi)使用
   <router-link to="/pkproperties">點(diǎn)擊跳轉(zhuǎn)</router-link>  // path路徑跳轉(zhuǎn)
   <router-link to="{name:'pkproperties',query:{id:1}}">點(diǎn)擊跳轉(zhuǎn)</router-link>  // 使用命名路由name跳轉(zhuǎn)

傳參配置:

 {
   path: '/pkproperties', // 路徑
   name:'pkproperties', // 路由名,path路徑必寫(xiě),用name跳轉(zhuǎn)的時(shí)候是根據(jù)name名找到path進(jìn)行跳轉(zhuǎn)
   component: () => import('@/views/pkproperties'), // 組件(組件文件名為index的可省略)
   hidden: true
  },
   // 使用命名路由傳參,可以傳遞基本數(shù)據(jù)類(lèi)型和數(shù)組和對(duì)象
   <router-link to="{name:'pkproperties',query:{id:1}}">點(diǎn)擊跳轉(zhuǎn)</router-link>  // name名跳轉(zhuǎn),query傳遞參數(shù)
   <router-link to="{name:'pkproperties',params:{id:1}}">點(diǎn)擊跳轉(zhuǎn)</router-link>  // name名跳轉(zhuǎn),params傳遞參數(shù)
   this.$route.query.id // 獲取傳遞的參數(shù)(.傳遞參數(shù)的鍵名)
   this.$route.params.id // 獲取傳遞的參數(shù)(.傳遞參數(shù)的鍵名)

2.編程式路由跳轉(zhuǎn)(最常用的,不受時(shí)機(jī)、條件的限制)

路由配置:

{
   path: '/pkproperties', // 路徑
   name:'pkproperties', // 路由名,path路徑必寫(xiě),用name跳轉(zhuǎn)的時(shí)候是根據(jù)name名找到path進(jìn)行跳轉(zhuǎn)
   component: () => import('@/views/pkproperties'), // 組件(組件文件名為index的可省略)
   hidden: true
  },

傳參配置:

methods:{
   onSkipTransferParameters(){
   // params傳參
        this.$router.push({
           name: "pkproperties",
           params: { 
           name: '小明',
           id: 1,
          },
        });
     onSkipTransferParameters(){
   // query傳參
        this.$router.push({
           name: "pkproperties",
           query: { 
           name: '小明',
           id: 1,
          },
        });
   }
 // 獲取傳遞的參數(shù)
 this.$route.params.name // 獲取就是在當(dāng)前跳轉(zhuǎn)的組件內(nèi)調(diào)用$route實(shí)例,是用params就.params.鍵名獲取值
 this.$route.query.name // 獲取就是在當(dāng)前跳轉(zhuǎn)的組件內(nèi)調(diào)用$route實(shí)例,是用query就.query.鍵名獲取值

query傳參在刷新界面后傳遞的數(shù)據(jù)不會(huì)丟失,params傳遞的參數(shù)刷新界面后會(huì)丟失參數(shù)。

3.路由重定向redirect需要用到傳參的業(yè)務(wù)

   { path:"/", redirect: {path:"pkproperties", query:{Pid:'1'}} },
   { path:"pkproperties", component: ()=>import("../views/pkproperties") }

解決路由重復(fù)點(diǎn)擊路由沉積的問(wèn)題

// 把這段代碼直接粘貼到router/index.js中的Vue.use(VueRouter)之前
const originalPush = VueRouter.prototype.push;
  VueRouter.prototype.push = function (location) {
  return originalPush.call(this, location).catch(err => { })
};

注意:一定要寫(xiě)在 Vue.use(VueRouter)之前否則無(wú)效

解決路由跳轉(zhuǎn)后不能回到頂部的頁(yè)面頂部的問(wèn)題

在跳轉(zhuǎn)到的組件里配置下面的代碼即可

 mounted() {
    /**
     * 路由跳轉(zhuǎn)回到頂部
     */
    // chrome
    document.body.scrollTop = 0;
    // firefox
    document.documentElement.scrollTop = 0;
    // safari
    window.pageYOffset = 0;
  },

路由導(dǎo)航守衛(wèi)和案例展示

路由前置導(dǎo)航守衛(wèi)(beforeEach

    // 全局導(dǎo)航守衛(wèi)beforeEach
router.beforeEach((to, from, next) => {
	// to要到哪個(gè)路由去
    // from從哪個(gè)路由來(lái)
    // next下一步(無(wú)論失敗與否都要調(diào)用,否則會(huì)阻止程序繼續(xù)執(zhí)行)
}

案例1中使用(攔截未登錄用戶(hù)和白名單設(shè)置):

permission.js文件下配置(permission文件最好和main文件在同一目錄下創(chuàng)建)

import router from './router'
import { getToken } from '@/common/TokenStore'
const whiteList = ['/login', '/register'] // 白名單登錄注冊(cè)界面無(wú)需驗(yàn)證Token是否登錄直接放行
// 全局導(dǎo)航守衛(wèi)beforeEach
router.beforeEach((to, from, next) => {
	// 白名單中路由直接放行
	if (whiteList.indexOf(to.path) !== -1) {
		next()
		return
	}
	// 判斷需要登錄身份認(rèn)證的路由
	const token = getToken() // 獲取token
	if (token) {
		next()
	} else {
		next(`/login`) // 如果登錄不存在,重定向到登錄界面
	}
})

main.js文件下引入即可

import './permission' // 引入即可

案例2中使用(設(shè)置Tokne失效實(shí)現(xiàn)攔截,Tokne失效就導(dǎo)航會(huì)登錄界面重新登錄,未失效就不執(zhí)行操作)

login.vue(登錄組件登錄成功后保存Token和保存獲取Token的當(dāng)前時(shí)間戳在本地)

    methods: {
      // 登錄
      handleLogin() {
        this.$axios.post('/api/Login',{
         username: this.loginForm.username, // 用戶(hù)名
         password: this.loginForm.password // 密碼
        }).then(res => { 
          if(res.data.code != 0) return this.$message.error(res.data.message) // code 不等于0,返回失敗的結(jié)果,(這的判斷參數(shù)是根據(jù)后端返回的數(shù)據(jù)進(jìn)行的,不是固定的)
          if(res.data.code == 0){
            this.$message.success('登錄成功')
            // 存儲(chǔ)token開(kāi)始時(shí)間
            window.localStorage.setItem('tokenStartTime',new Date().getTime())
            // 存儲(chǔ)token
            window.localStorage.setItem('token',res.data.data.token)
            this.$router.push('/home/ks')
          }else {
            this.$message.error('登錄失敗')
          }
        })
      }
}

permission.js(將保存的Token獲取時(shí)間和當(dāng)前時(shí)間進(jìn)行一個(gè)差值的比較,如果小于我們?cè)O(shè)定的Token失效時(shí)間,就證明登錄沒(méi)有過(guò)期可繼續(xù)訪問(wèn),如果大于就登錄過(guò)期Token失效需要重新登錄獲取。)

// 導(dǎo)入element提示語(yǔ)的組件可以去element-ui查看用法,這是按需引入的
import {
    Message
} from 'element-ui'
// 添加請(qǐng)求攔截器
// 攔截器的第二部分,第一部分在main.js里面
router.beforeEach((to, from, next) => {
  // 獲取存儲(chǔ)localStorage的token
  let token = window.localStorage.getItem('token')
  // 獲取存儲(chǔ)token的開(kāi)始時(shí)間
  const tokenStartTime = window.localStorage.getItem('tokenStartTime')
  // 后臺(tái)給出的token有效時(shí)間為一天,這個(gè)是后端給的時(shí)間以后端為準(zhǔn)
  const timeOver = 86400000
  // 獲取當(dāng)前時(shí)間
  let date = new Date().getTime()
  // 當(dāng)前時(shí)間減去獲取Token的時(shí)間如果大于說(shuō)明是token過(guò)期了
  if(date - tokenStartTime > timeOver) {
      token = null // Token過(guò)期賦值為null
  }
  // 如果token過(guò)期了
  if (!token) {
    if (to.path == '/login') return next()
    // 注意要import element的Message組件
    Message.error("登錄狀態(tài)過(guò)期,請(qǐng)重新登錄")
    return next('/login')
    // 如果token沒(méi)有過(guò)期,又是選擇了登錄頁(yè)面就直接重定向到首頁(yè),不需要重新輸入賬戶(hù)密碼
  } else if (to.path == '/login') {
    return next('/home/ks')
  }
  next()
 
})
export default router

全局后置守衛(wèi)(afterEach

router.afterEach((to,from)=>{<!--{cke_protected}{C}%3C!%2D%2D%20%2D%2D%3E-->})

組件內(nèi)守衛(wèi)(相當(dāng)于給組件增加生命周期)

beforeRouteEnter 進(jìn)入組件之前
beforeRouterEnter(to,from,next){}

beforeRouteUpdate 組件被復(fù)用時(shí)調(diào)用
beforeRouterUpdate(to,from,next){}

beforeRouteLeave 離開(kāi)組件時(shí)調(diào)用
beforeRouteLeave(to,from,next){}

訪問(wèn)外部鏈接

vue內(nèi)部跳轉(zhuǎn)可以通過(guò)vue-router中的this.$router.push()和rout-link 來(lái)實(shí)現(xiàn),這里在說(shuō)一下想要訪問(wèn)外部鏈接的方法

1.window.location.href = url(不新開(kāi)一個(gè)頁(yè)面,直接在當(dāng)前頁(yè)面跳轉(zhuǎn))

methods:{
  onSkip(){
    window.location.
  }
}

2.window.open(“url”, “_blank”)(打開(kāi)一個(gè)新頁(yè)面跳轉(zhuǎn))

methods:{
  onSkip(){
    window.open("https://xxx.xxx.xxx/", "_blank");
  }
}

3.手動(dòng)創(chuàng)建a標(biāo)簽,然后默認(rèn)點(diǎn)擊

 var a = document.createElement("a");
     a.setAttribute("href", "www.baidu.com");
     a.setAttribute("target", "_blank");
     a.click();

到此這篇關(guān)于Vue路由應(yīng)用詳細(xì)講解的文章就介紹到這了,更多相關(guān)Vue路由內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 前端vue+elementUI如何實(shí)現(xiàn)記住密碼功能

    前端vue+elementUI如何實(shí)現(xiàn)記住密碼功能

    這篇文章主要給大家介紹了關(guān)于vue+elementUI如何實(shí)現(xiàn)記住密碼功能的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-09-09
  • 解決vue中監(jiān)聽(tīng)input只能輸入數(shù)字及英文或者其他情況的問(wèn)題

    解決vue中監(jiān)聽(tīng)input只能輸入數(shù)字及英文或者其他情況的問(wèn)題

    今天小編就為大家分享一篇解決vue中監(jiān)聽(tīng)input只能輸入數(shù)字及英文或者其他情況的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-08-08
  • 使用Vue封裝一個(gè)自定義的右鍵菜單組件

    使用Vue封裝一個(gè)自定義的右鍵菜單組件

    通過(guò)自定義右鍵菜單欄,用戶(hù)可以根據(jù)自己的需求添加、調(diào)整和刪除菜單選項(xiàng),所以本文就來(lái)為大家介紹一下如何使用使用Vue封裝一個(gè)自定義的右鍵菜單組件吧
    2024-01-01
  • vue-cli項(xiàng)目?jī)?yōu)化方法- 縮短首屏加載時(shí)間

    vue-cli項(xiàng)目?jī)?yōu)化方法- 縮短首屏加載時(shí)間

    這篇文章主要介紹了vue-cli項(xiàng)目?jī)?yōu)化 縮短首屏加載時(shí)間,需要的朋友可以參考下
    2018-04-04
  • VUE表達(dá)式{{}}中如何拼接字符

    VUE表達(dá)式{{}}中如何拼接字符

    這篇文章主要介紹了VUE表達(dá)式{{}}中如何拼接字符問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-07-07
  • vue-resource 攔截器interceptors使用詳解

    vue-resource 攔截器interceptors使用詳解

    這篇文章主要介紹了vue-resource 攔截器interceptors使用詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2021-01-01
  • vue如何實(shí)現(xiàn)動(dòng)態(tài)改變地址欄的參數(shù)值

    vue如何實(shí)現(xiàn)動(dòng)態(tài)改變地址欄的參數(shù)值

    這篇文章主要介紹了vue如何實(shí)現(xiàn)動(dòng)態(tài)改變地址欄的參數(shù)值,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-07-07
  • vue實(shí)現(xiàn)element上傳多張圖片瀏覽刪除功能

    vue實(shí)現(xiàn)element上傳多張圖片瀏覽刪除功能

    這篇文章主要介紹了vue實(shí)現(xiàn)element上傳多張圖片瀏覽刪除功能,本文結(jié)合示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧
    2023-10-10
  • vue+el-table實(shí)現(xiàn)合并單元格

    vue+el-table實(shí)現(xiàn)合并單元格

    這篇文章主要為大家詳細(xì)介紹了vue+el-table實(shí)現(xiàn)合并單元格,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-09-09
  • 詳解Vue computed計(jì)算屬性是什么

    詳解Vue computed計(jì)算屬性是什么

    在vue中,有時(shí)候你需要對(duì)data中的數(shù)據(jù)進(jìn)行處理,或者對(duì)抓取的數(shù)據(jù)進(jìn)行處理之后再掛載呈現(xiàn)到標(biāo)簽中,這時(shí)候你就需要計(jì)算屬性了,當(dāng)然看到這里你可能還是不了解那下面我舉幾個(gè)實(shí)例并附代碼解釋
    2023-03-03

最新評(píng)論