成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

Vue-Router(vue路由)

hover_lew / 1757人閱讀

摘要:你可以使用注冊一個全局的鉤子鉤子函數(shù)的三個參數(shù)即將要進入的目標路由對象當前導(dǎo)航正要離開的路由一定要調(diào)用該方法來這個鉤子。

Vue-router(路由)

在web開發(fā)中,"router"是指根據(jù)url分配到對應(yīng)的處理程序

CDN引入:
//vue


//vue-router
NPM安裝
npm install vue-router
開始使用

在使用Vue.js的時候,我們通過組合組件來組成應(yīng)用程序,現(xiàn)在我們要把vue-router添加進來,只需要將組件(components)映射到路由(routes),然后告訴 vue-router 在哪里渲染它們。

Hello App!

Go to Foo Go to Bar

注意,如果使用模塊化編程。就需要導(dǎo)入vue和VueRouter,在js中調(diào)用 Vue.use(VueRouter)

動態(tài)路由

例如,我們有一個 User 組件,對于所有 ID 各不相同的用戶,都要使用這個組件來渲染。那么,我們可以在 vue-router 的路由路徑中使用『動態(tài)路徑參數(shù)』(dynamic segment)來達到這個效果:

HTML

div id="app">
    

Hello App!

Go to Foo
Go to Bar
user

JAVASCRIPT

onst Foo = { template: "
foo
" } const Bar = { template: "
bar
" } const User = {template:`

user

{{$route.params.name}}
` } const routes = [ { path: "/foo", component: Foo }, { path: "/bar", component: Bar }, { path:"/user", component:User, children:[ { path:":name"http://動態(tài)路徑參數(shù)以冒號開頭 } ] } ] const router = new VueRouter({ routes }) const app = new Vue({ el:"#app", router })
 嵌套路由

借助 vue-router,使用嵌套路由配置,就可以很簡單地表達組件中的層級關(guān)系

實際上,在上面的動態(tài)路由的例子中就已經(jīng)使用了嵌套了,定義路由時添加一個 children 屬性即可:

const routes=[
    {
        path:"/user",
        component:User,
        children:[
            {
                path:":name",
                component:{
                    template:"
pureview
" } } ] } ]
編程式導(dǎo)航 router.push()

< router-view >標簽在模板中會被渲染為一個< a >標簽來進行鏈接,其實,也可以使用 "router.push()" 來實現(xiàn)導(dǎo)航

該方法的參數(shù)可以是一個字符串路徑,或者一個描述地址的對象。例如:

// 字符串
router.push("home")

// 對象
router.push({ path: "home" })

// 命名的路由
router.push({ name: "user", params: { userId: 123 }})

// 帶查詢參數(shù),變成 /register?plan=private
router.push({ path: "register", query: { plan: "private" }})
router.replace()

跟 router.push 很像,唯一的不同就是,它不會向 history 添加新記錄,而是跟它的方法名一樣 —— 替換掉當前的 history 記錄。

router.go(n)

這個方法的參數(shù)是一個整數(shù),意思是在 history 記錄中向前或者后退多少步,類似 window.history.go(n)。

// 在瀏覽器記錄中前進一步,等同于 history.forward()
router.go(1)

// 后退一步記錄,等同于 history.back()
router.go(-1)

// 前進 3 步記錄
router.go(3)

// 如果 history 記錄不夠用,那就默默地失敗唄
router.go(-100)
router.go(100)
命名路由

路由組件是可以進行命名的,在執(zhí)行鏈接或者跳轉(zhuǎn)頁面時就會比較方便。命名的方式也很簡單,給routes一個name屬性就OK了

var router=new VueRouter({
    routes:[
        {
            path:"/home",
            name:"homePage",
            component:Home
        }
    ]
})

要鏈接到一個命名路由,可以給 router-link 的 to 屬性傳一個對象:

Home
命名視圖

有時候想同時(同級)展示多個視圖,而不是嵌套展示,例如創(chuàng)建一個布局,有 sidebar(側(cè)導(dǎo)航) 和 main(主內(nèi)容) 兩個視圖,這個時候命名視圖就派上用場了。你可以在界面中擁有多個多帶帶命名的視圖,而不是只有一個多帶帶的出口。如果 router-view 沒有設(shè)置名字,那么默認為 default。

HTML

視圖一

視圖二

JAVASCRIPT

var Foo={
    template:"
內(nèi)容一
" } var Bar={ template:"
內(nèi)容二
" } var routes=[ { path:"/", components:{ one:Foo, two:Bar } } ] var router=new VueRouter({ routes })
重定向

重定向的意思就是當你訪問 a 的時候,url 會被替換為 b ,于是匹配路由 b

重定向也是通過 routes 配置來完成,下面例子是從 /a 重定向到 /b:

var router=new VueRouter({
    routes:[
        {
            path:"/a",
            redirect:"/b"
        }
    ]
})
別名

意思就是當我們訪問 b 的時候,路由匹配為 a ,但是url地址不變

var router=new VueRouter({
    routes:[
        {
            path:"/a",
            alias:"/b"
        }
    ]
})
路由高級 導(dǎo)航鉤子

vue-router 提供的導(dǎo)航鉤子主要用來攔截導(dǎo)航,讓它完成跳轉(zhuǎn)或取消。有多種方式可以在路由導(dǎo)航發(fā)生時執(zhí)行鉤子:全局的, 單個路由獨享的, 或者組件級的。

你可以使用 router.beforeEach 注冊一個全局的 before 鉤子:

router .beforeEach((to,from,next)=>{
    //...
})

鉤子函數(shù)的三個參數(shù):

to: Route: 即將要進入的目標 路由對象

from: Route: 當前導(dǎo)航正要離開的路由

next: Function: 一定要調(diào)用該方法來 resolve 這個鉤子。執(zhí)行效果依賴 next 方法的調(diào)用參數(shù)。

next(): 進行管道中的下一個鉤子。如果全部鉤子執(zhí)行完了,則導(dǎo)航的狀態(tài)就是 confirmed (確認的)。

next(false): 中斷當前的導(dǎo)航。如果瀏覽器的 URL 改變了(可能是用戶手動或者瀏覽器后退按鈕),那么 URL 地址會重置到 from 路由對應(yīng)的地址。

next("/") 或者 next({ path: " / " }): 跳轉(zhuǎn)到一個不同的地址。當前的導(dǎo)航被中斷,然后進行一個新的導(dǎo)航。

做一個小例子:

做了一個簡單的頁面,設(shè)定了一個登陸狀態(tài),如果 isLogin 為false,那么點擊賬戶中心,則跳轉(zhuǎn)到登陸頁進行登陸

如果 isLogin 為true,則顯示賬戶中心的內(nèi)容:

鉤子函數(shù)代碼

router.beforeEach((to, from, next) => {
    var isLogin = true ;
    if(to.path == "/user"&&!isLogin){
        next("/login")
    }else{
        next();
    }
})

貼上完整代碼大家可以直接復(fù)制試一試

首頁 關(guān)于我們 賬戶中心 登錄

路由元信息

定義路由的時候可以配置 meta 字段:

const router = new VueRouter({
  routes: [
    {
      path: "/foo",
      component: Foo,
      children: [
        {
          path: "bar",
          component: Bar,
          meta: { requiresAuth: true }
        }
      ]
    }
  ]
})

那么如何訪問這個 meta 字段呢?

首先,我們稱呼 routes 配置中的每個路由對象為 路由記錄。路由記錄可以是嵌套的,因此,當一個路由匹配成功后,他可能匹配多個路由記錄。

例如,根據(jù)上面的路由配置,/foo/bar 這個 URL 將會匹配父路由記錄以及子路由記錄。

一個路由匹配到的所有路由記錄會暴露為 $route 對象(還有在導(dǎo)航鉤子中的 route 對象)的 $route.matched 數(shù)組。因此,我們需要遍歷 $route.matched 來檢查路由記錄中的 meta 字段。

下面例子展示在全局導(dǎo)航鉤子中檢查 meta 字段:

router.beforeEach((to, from, next) => {
  if (to.matched.some(record => record.meta.requiresAuth)) {
    // 此路由需要驗證,檢查是否登錄
    // 如果不需要,則重定向到登錄頁面。
    if (!auth.loggedIn()) {
      next({
        path: "/login",
        query: { redirect: to.fullPath }
      })
    } else {
      next()
    }
  } else {
    next() // 確保一定要調(diào)用 next()
  }
})

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/88542.html

相關(guān)文章

  • 從頭開始學(xué)習vue-router

    摘要:路由模塊的本質(zhì)就是建立起和頁面之間的映射關(guān)系。這時候我們可以直接利用傳值了使用來匹配路由,然后通過來傳遞參數(shù)跳轉(zhuǎn)對應(yīng)路由配置于是我們可以獲取參數(shù)六配置子路由二級路由實際生活中的應(yīng)用界面,通常由多層嵌套的組件組合而成。 一、前言 要學(xué)習vue-router就要先知道這里的路由是什么?為什么我們不能像原來一樣直接用標簽編寫鏈接哪?vue-router如何使用?常見路由操作有哪些?等等這些問...

    tommego 評論0 收藏0
  • 從頭開始學(xué)習vue-router

    摘要:路由模塊的本質(zhì)就是建立起和頁面之間的映射關(guān)系。這時候我們可以直接利用傳值了使用來匹配路由,然后通過來傳遞參數(shù)跳轉(zhuǎn)對應(yīng)路由配置于是我們可以獲取參數(shù)六配置子路由二級路由實際生活中的應(yīng)用界面,通常由多層嵌套的組件組合而成。 一、前言 要學(xué)習vue-router就要先知道這里的路由是什么?為什么我們不能像原來一樣直接用標簽編寫鏈接哪?vue-router如何使用?常見路由操作有哪些?等等這些問...

    jhhfft 評論0 收藏0
  • 從頭開始學(xué)習vue-router

    摘要:路由模塊的本質(zhì)就是建立起和頁面之間的映射關(guān)系。這時候我們可以直接利用傳值了使用來匹配路由,然后通過來傳遞參數(shù)跳轉(zhuǎn)對應(yīng)路由配置于是我們可以獲取參數(shù)六配置子路由二級路由實際生活中的應(yīng)用界面,通常由多層嵌套的組件組合而成。 一、前言 要學(xué)習vue-router就要先知道這里的路由是什么?為什么我們不能像原來一樣直接用標簽編寫鏈接哪?vue-router如何使用?常見路由操作有哪些?等等這些問...

    frontoldman 評論0 收藏0
  • vue-router 基礎(chǔ)知識點

    摘要:路由模塊的本質(zhì)就是建立起和頁面之間的映射關(guān)系。模式的原理是事件監(jiān)測值變化,可以在對象上監(jiān)聽這個事件。這兩個方法應(yīng)用于瀏覽器記錄棧,在當前已有的基礎(chǔ)之上,它們提供了對歷史記錄修改的功能。 vue-router 這里的路由并不是指我們平時所說的硬件路由器,這里的路由就是SPA(單頁應(yīng)用)的路徑管理器。再通俗的說,vue-router就是WebApp的鏈接路徑管理系統(tǒng)。vue-router是...

    ningwang 評論0 收藏0
  • [使用 Weex 和 Vue 開發(fā)原生應(yīng)用] 6 使用 vue-router

    摘要:使用值來作路由。原生應(yīng)用本身就是多頁的場景,頁面間狀態(tài)的隔離比共享更重要一些。使用開發(fā)的是原生應(yīng)用,頁面棧的管理使用的也是原生的特性,沒有但是有模塊可以實現(xiàn)頁面的前進和后退等操作。 系列文章的目錄在 ? 這里 (由于 我比較懶 最近一段時間在忙其他事,系列文章拖了好久終于又更新了。。。) 什么是 vue-router ? vue-router 官方文檔 vue-router 是針對 V...

    leonardofed 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<