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

資訊專欄INFORMATION COLUMN

VueRouter

劉厚水 / 1842人閱讀

摘要:當(dāng)對應(yīng)的路由匹配成功,將自動設(shè)置屬性值。執(zhí)行效果依賴方法的調(diào)用參數(shù)。而這個鉤子就會在這個情況下被調(diào)用。滾動行為只在支持的瀏覽器中可用。當(dāng)且僅當(dāng)導(dǎo)航通過瀏覽器的前進后退按鈕觸發(fā)時才可用。

當(dāng)  對應(yīng)的路由匹配成功,將自動設(shè)置 class 屬性值 .router-link-active 。

默認 hash 模式:使用 URL 的 hash 來模擬一個完整的 URL,于是當(dāng) URL 改變時,頁面不會重新加載。
history 模式:充分利用 history.pushState API 來完成 URL 跳轉(zhuǎn)而無須重新加載頁面,此模式如果 URL 匹配不到任何靜態(tài)資源,則應(yīng)該返回同一個 index.html 頁面。

動態(tài)路由匹配
{path: "/user/:id", component: User}
user/abc user/123 都將映射到相同的路由
this.$route.params.id(template 中 $route.params.id)

{path: "/user-*"} 匹配以 `/user-` 開頭的任意路徑

嵌套路由
User 需要 
children 路徑不能以 "/" 開頭
{
  path: "/user",
  component: User,
  children: [
    {
      // 當(dāng) /user/profile 匹配成功,
      // UserProfile 會被渲染在 User 的  中
      path: "profile",
      component: UserProfile
    },
    {
      // 當(dāng) /user/posts 匹配成功
      // UserPosts 會被渲染在 User 的  中
      path: "posts",
      component: UserPosts
    }
  ]
}

編程式的導(dǎo)航
 等同于調(diào)用 router.push(...)
this.$router.push(location, onComplete?, onAbort?)
this.$router.push("home")
this.$router.push({ path: "register", query: { plan: "private" }})
this.$router.push({ name: "user", params: { userId: "123" }})

location 如果提供了 path,params 會被忽略,解決辦法:{path: `register/${id}`}

onComplete 和 onAbort 兩個回調(diào)用于導(dǎo)航成功完成(在所有的異步鉤子被解析之后)或終止(導(dǎo)航到相同的路由、或在當(dāng)前導(dǎo)航完成之前導(dǎo)航到另一個不同的路由)的時候進行相應(yīng)的調(diào)用

 等同于調(diào)用 router.replace(...),和 router.push() 唯一的不同就是,它不會向 history 添加新記錄,而是替換掉當(dāng)前的 history 記錄

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


命名視圖




{
  path: "/",
  components: {
    default: Foo,
    a: Bar,
    b: Baz
  }
}


重定向和別名
{ path: "/a", redirect: "/b" }
{ path: "/a", redirect: { name: "foo" }}
{ path: "/a", redirect: to => {
  // 方法接收 目標(biāo)路由 作為參數(shù)
  // return 重定向的 字符串路徑/路徑對象
}}

{ path: "/a", component: A, alias: "/b" }


導(dǎo)航守衛(wèi)
全局前置守衛(wèi)
router.beforeEach((to, from, next) => {
  // to: Route: 即將要進入的目標(biāo) 路由對象
  // from: Route: 當(dāng)前導(dǎo)航正要離開的路由
  // next: Function: 一定要調(diào)用該方法來 resolve 這個鉤子。執(zhí)行效果依賴 next 方法的調(diào)用參數(shù)。
  // some code
  next()
})

全局后置鉤子
router.afterEach((to, from) => {
  // ...
})

路由獨享的守衛(wèi)
{
  path: "/foo",
  component: Foo,
  beforeEnter: (to, from, next) => {/* */}
}

組件內(nèi)的守衛(wèi)
const Foo = {
  template: `...`,
  beforeRouteEnter (to, from, next) {
    // 在渲染該組件的對應(yīng)路由被 confirm 前調(diào)用
    // 【不能】獲取組件實例 `this`,不過,你可以通過傳一個回調(diào)給 next來訪問組件實例
    next(vm => {
      // 通過 `vm` 訪問組件實例
    })
    // 因為當(dāng)守衛(wèi)執(zhí)行前,組件實例還沒被創(chuàng)建
  },
  beforeRouteUpdate (to, from, next) {
    // 在當(dāng)前路由改變,但是該組件被復(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`
  }
}

路由元信息
{
  path: "bar",
  component: Bar,
  meta: { requiresAuth: true, title: "BAR" }
}
遍歷 $route.matched 來檢查路由記錄中的 meta 字段。

滾動行為
scrollBehavior 只在支持 history.pushState 的瀏覽器中可用。
new VueRouter({
  routes: [...],
  scrollBehavior (to, from, savedPosition) {
    // savedPosition 當(dāng)且僅當(dāng) popstate 導(dǎo)航 (通過瀏覽器的 前進/后退 按鈕觸發(fā)) 時才可用。
    // return 期望滾動到哪個的位置
  }
})


路由懶加載
const Foo = () => import("./Foo.vue")

https://router.vuejs.org/zh/

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

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

相關(guān)文章

  • VueRouter基礎(chǔ)

    摘要:的路徑的路由組件點擊后的結(jié)果你會發(fā)現(xiàn)被匹配后中的就會接收到字符串,因此輸出結(jié)果如圖所示對象模式如果是一個對象,它會被按原樣設(shè)置為組件屬性。最終的就是傳入的 安裝 直接下載(官方CDN) https://unpkg.com/vue-router/...通過頁面script標(biāo)簽引入,如下: NPM安裝 npm install vue-router --save-dev 安裝完成后需要Vu...

    FreeZinG 評論0 收藏0
  • VueRouter基礎(chǔ)

    摘要:的路徑的路由組件點擊后的結(jié)果你會發(fā)現(xiàn)被匹配后中的就會接收到字符串,因此輸出結(jié)果如圖所示對象模式如果是一個對象,它會被按原樣設(shè)置為組件屬性。最終的就是傳入的 安裝 直接下載(官方CDN) https://unpkg.com/vue-router/...通過頁面script標(biāo)簽引入,如下: NPM安裝 npm install vue-router --save-dev 安裝完成后需要Vu...

    Aklman 評論0 收藏0
  • VueRouter基礎(chǔ)

    摘要:的路徑的路由組件點擊后的結(jié)果你會發(fā)現(xiàn)被匹配后中的就會接收到字符串,因此輸出結(jié)果如圖所示對象模式如果是一個對象,它會被按原樣設(shè)置為組件屬性。最終的就是傳入的 安裝 直接下載(官方CDN) https://unpkg.com/vue-router/...通過頁面script標(biāo)簽引入,如下: NPM安裝 npm install vue-router --save-dev 安裝完成后需要Vu...

    golden_hamster 評論0 收藏0
  • Vue源碼解析

    摘要:系列文章鏈接主要記錄自己開始學(xué)習(xí)的一些源碼閱讀基于版本介紹了構(gòu)造函數(shù)如何來的,以及其上的屬性方法原型方法靜態(tài)方法的過程發(fā)生了什么對象如何生成對象如何掛載到真實的節(jié)點介紹了的插入,的使用,實例的生成實例對象上的和對象的創(chuàng)建中的組件和的源碼 系列文章鏈接主要記錄自己開始學(xué)習(xí)Vue的一些源碼閱讀:基于2.5.8版本 Vue-SourceCode 介紹了 Vue構(gòu)造函數(shù)如何來的,以及其上的屬...

    zgbgx 評論0 收藏0
  • 一步步從零開始學(xué)習(xí)vue-router

    摘要:前言一個包含的簡單,從第一個開始,依次深入學(xué)習(xí),即可快速上手強大的。 前言 一個包含 vue-router的簡單demos,從第一個demo開始,依次深入學(xué)習(xí),即可快速上手強大的vue-router。 如何使用 安裝模塊pure 或 http-server來啟動服務(wù)器npm install -g puer or npm install -g http-server 克隆倉庫 啟動服...

    Cobub 評論0 收藏0
  • VueRouter進階一(導(dǎo)航鉤子和路由元信息)

    摘要:有多種方式可以在路由導(dǎo)航發(fā)生時執(zhí)行鉤子全局的單個路由獨享的或者組件級的。進行管道中的下一個鉤子。當(dāng)前的導(dǎo)航被中斷,然后進行一個新的導(dǎo)航。通過訪問組件實例路由元信息你可以在中直接訪問。 導(dǎo)航鉤子 vue-router 提供的導(dǎo)航鉤子主要用來攔截導(dǎo)航,讓它完成跳轉(zhuǎn)或取消。有多種方式可以在路由導(dǎo)航發(fā)生時執(zhí)行鉤子:全局的, 單個路由獨享的, 或者組件級的。 全局鉤子 你可以使用 router....

    liukai90 評論0 收藏0

發(fā)表評論

0條評論

劉厚水

|高級講師

TA的文章

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