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

vue中vue-router的使用說明(包括在ssr中的使用)

 更新時間:2022年05月25日 11:19:19   作者:可能是魚  
這篇文章主要介紹了vue中vue-router的使用說明(包括在ssr中的使用),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

vue筆記之vue-router的使用(包括ssr中的使用)

安裝vue-router

命令行執(zhí)行:

npm i vue-router -S

創(chuàng)建配置文件

在項目src文件夾下創(chuàng)建config文件夾存放路由配置

在config文件夾下新建router.js和routes.js

  • router.js: 存放路由設(shè)置
  • routes.js: 存放理由映射規(guī)則

路由映射規(guī)則配置

import Login from '../views/login/login .vue'
// import 組件名 from '組件路徑'
import Register from '../views/register/register.vue'
import ChildrenVue from '../views/children/children.vue'
export default [
  {
    path: '/',
    redirect: '/login'
  },
  {
    path: '/login',
    component: Login ,
    name: 'login',
    meta: { //保存頁面信息
      title: 'this is Login ',
      description: 'this is Login description'
    },
    children: [ //子路由
      {
         path: '/children',
         component: ChildrenVue
      }
    ]
  },
  {
    path: '/register',
    component: Register,
    name: 'register'
  }
]

路由設(shè)置內(nèi)容

基本配置:

import Router from 'vue-router'?
import routes from './routes' //導(dǎo)入router 映射規(guī)則
const router = ?new Router({
? ?routes
})
export default router

若使用服務(wù)端渲染改寫為:

import Router from 'vue-router'?
import routes from './routes' //導(dǎo)入router 映射規(guī)則
//每次import都創(chuàng)建一個新的router 避免內(nèi)存溢出
export default () => {
? ?return new Router({
? ? ?routes,
? ? ?mode: 'history' //改為history模式方便服務(wù)端渲染做SEO
? ?})
}

入口文件配置

import Vue from 'vue'
import VueRouter from 'vue-router'
import createRouter from './config/router' //導(dǎo)入router配置文件
Vue.use(VueRouter)
const router = createRouter()?
new Vue({
? router,
? render: (h) => h(App)
}).$mount('#root')

app.vue配置

在app.vue中加入:

<router-view></router-view>

給router-view添加切換動畫:

<transition name="fade">
? <router-view></router-view>
</transition>

css:

.fade-enter-active, .fade-leave-active {
? transition: opacity .5s;
}
.fade-enter, .fade-leave-to {
? opacity: 0;
}

router中使用props

路由之前傳參可以使用this.$route拿到參數(shù)也可以使用props:

{
? ? path: '/login',
? ? props: (route) => ({id: route.query.id}),
? ? component: Login,
},

在login頁面的export default添加props:

export default {
? props: ['id'],
? mounted () {
? ? console.log(this.id) //打印傳遞的參數(shù)
? },
}

瀏覽器訪問得到結(jié)果:

在這里插入圖片描述

其他配置屬性

base:

export default () => {
  return new Router({
    routes,
    mode: 'history',
    base: '/base/'
  })
}

設(shè)置base之后瀏覽器訪問頁面路由path前面會自動加上base配置的值

在這里插入圖片描述

scrollBehavior :

//scrollBehavior 記錄頁面滾動的位置下次進來直接滾動到記錄的位置
export default () => {
  return new Router({
    routes,
    mode: 'history',
    scrollBehavior (to, from, savedPosition) {
       //savedPosition 記錄的位置 如果沒有返回最初位置
      if (savedPosition) {
        return savedPosition
      } else {
        return {x: 0, y: 0}
      }
    }
  })
}

導(dǎo)航守衛(wèi)

入口文件中配置全局導(dǎo)航守衛(wèi):

import Vue from 'vue'
import VueRouter from 'vue-router'
import createRouter from './config/router' //導(dǎo)入router配置文件
Vue.use(VueRouter)
const router = createRouter() 
// 導(dǎo)航守衛(wèi)-start
router.beforeEach((to, from, next) => {
  console.log('before each invoked')
  next()
})
router.beforeResolve((to, from, next) => {
  console.log('before resolve invoked')
  next()
})
router.afterEach((to, from) => {
  console.log('after each invoked')
})
// 導(dǎo)航守衛(wèi)-end
new Vue({
  router,
  render: (h) => h(App)
}).$mount('#root')

組件內(nèi)部導(dǎo)航守衛(wèi)配置:

const footer = {
  template: `<div>footer</div>`,
  beforeRouteEnter (to, from, next) {
    // 在渲染該組件的對應(yīng)路由被 confirm 前調(diào)用
    // 不!能!獲取組件實例 `this`
    // 因為當守衛(wèi)執(zhí)行前,組件實例還沒被創(chuàng)建
  },
  beforeRouteUpdate (to, from, next) {
    // 在當前路由改變,但是該組件被復(fù)用時調(diào)用
    // 舉例來說,對于一個帶有動態(tài)參數(shù)的路徑 /foo/:id,在 /foo/1 和 /foo/2 之間跳轉(zhuǎn)的時候,
    // 由于會渲染同樣的 Foo 組件,因此組件實例會被復(fù)用。而這個鉤子就會在這個情況下被調(diào)用。
    // 可以訪問組件實例 `this`
  },
  beforeRouteLeave (to, from, next) {
    // 導(dǎo)航離開該組件的對應(yīng)路由時調(diào)用
    // 可以訪問組件實例 `this`
  }
}

每個路由獨享的導(dǎo)航守衛(wèi)配置:

{
    path: '/login',
    component: Login,
    beforeEnter: (to, from, next) => {
      //...
    },
    beforeResolve: (to, from, next) => {
      //...
    },
    afterEach: (to, from, next) => {
      //...
    }
},

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • Vue中使用ElementUI使用第三方圖標庫iconfont的示例

    Vue中使用ElementUI使用第三方圖標庫iconfont的示例

    這篇文章主要介紹了Vue中使用ElementUI使用第三方圖標庫iconfont的示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-10-10
  • 使用 JSON.stringify() 列化一個Error

    使用 JSON.stringify() 列化一個Error

    這篇文章主要介紹了使用 JSON.stringify() 列化一個Error,需要的朋友可以參考下
    2023-10-10
  • 詳解如何添加babel?polyfill

    詳解如何添加babel?polyfill

    這篇文章主要介紹了詳解vue如何添加babel?polyfill實現(xiàn)方法,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-06-06
  • vue 2.1.3 實時顯示當前時間,每秒更新的方法

    vue 2.1.3 實時顯示當前時間,每秒更新的方法

    今天小編就為大家分享一篇vue 2.1.3 實時顯示當前時間,每秒更新的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-09-09
  • vue路由守衛(wèi),限制前端頁面訪問權(quán)限的例子

    vue路由守衛(wèi),限制前端頁面訪問權(quán)限的例子

    今天小編就為大家分享一篇vue路由守衛(wèi),限制前端頁面訪問權(quán)限的例子,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-11-11
  • vue項目中按鈕防抖處理實現(xiàn)過程

    vue項目中按鈕防抖處理實現(xiàn)過程

    這篇文章主要給大家介紹了關(guān)于vue項目中按鈕防抖處理實現(xiàn)的相關(guān)資料,在項目開發(fā)中相必大家時常會遇到按鈕重復(fù)點擊后引起事件重復(fù)提交的問題,需要的朋友可以參考下
    2023-08-08
  • Vue設(shè)置瀏覽器小圖標(ICON)的詳細步驟

    Vue設(shè)置瀏覽器小圖標(ICON)的詳細步驟

    vue中網(wǎng)頁圖標默認使用的是vue自帶的一個icon的圖標,也是vue的logo,下面這篇文章主要給大家介紹了關(guān)于Vue設(shè)置瀏覽器小圖標(ICON)的詳細步驟,需要的朋友可以參考下
    2023-01-01
  • Vue中比較流行且好用的組件使用示例

    Vue中比較流行且好用的組件使用示例

    這篇文章主要介紹了Vue中比較流行且好用的一些組件使用示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-08-08
  • Vue中emit事件無法觸發(fā)的問題及解決

    Vue中emit事件無法觸發(fā)的問題及解決

    這篇文章主要介紹了Vue中emit事件無法觸發(fā)的問題及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-09-09
  • vue+antd實現(xiàn)折疊與展開組件

    vue+antd實現(xiàn)折疊與展開組件

    這篇文章主要為大家詳細介紹了vue+antd實現(xiàn)折疊與展開組件,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-09-09

最新評論