vue3如何使用vue-router

上一篇文章講了vue3+vue-cli4x如何創(chuàng)建項目 傳送門

vue-router@next文檔 該文檔暫時還沒有中文

現(xiàn)在我們來講一下vue3如何使用vue-router
打開剛剛創(chuàng)建的vue3+vue-cli4x項目的package.json文件可以看到?jīng)]有給我們提供vue-router,我們需要自己安裝

package.json

安裝vue-router@next

$ npm install vue-router@4.0.0-beta.13

安裝完成

安裝完成

打開main.js 發(fā)現(xiàn)變化挺大的 附上vue2vue3的對比
vue2和vue3的對比

我們在src下創(chuàng)建route文件夾和下面的index.js
創(chuàng)建文件夾

打開index.js 引入router

import { createRouter,createWebHashHistory} from "vue-router";

這里我們使用hash模式 需要history模式的同學請點擊這路由模式
這里方便演示我們在src文件夾下創(chuàng)建兩個頁面

創(chuàng)建頁面

router中注冊

const home = () => import("../home")
const login = () => import("../login")

const routes = [
  { path: "/", redirect: "/home" },
  {
    path: "/home",
    name: "home",
    component: home
  },
  {
    path: "/login",
    name: "login",
    component: login
  }
]

然后導出router

export const router = createRouter({
  history: createWebHashHistory(),
  routes: routes
})

這里我們修改一下main.js 方便我們使用

修改main.js

main.js中引入router 并掛載

import { createApp } from 'vue'
import App from './App.vue'
import router from './route'

const app = createApp(App)
app.use(router)
app.mount('#app')

到這里就完成了引入和掛載绍撞,現(xiàn)在來講一下如何在頁面中使用
打開login.vue
html中添加一個按鈕并綁定一個點擊事件

<template>
  <p>index</p>
  <button @click="toHome">toHome</button>
</template>

接著我們在頁面中引入router并使用

<script>
import { useRoute, useRouter } from 'vue-router'
export default {
  setup () {
    const route = useRoute()
    const router = useRouter()
    return {}
  },
}

引入的useRoute,useRouter 相當于vue2的 this.$route()this.$router()
點擊按鈕就能跳轉到home.vue頁面了

import { useRouter } from 'vue-router'
export default {
  setup () {
    const router = useRouter()
    const toHome = (() => {
      router.push({
        name: 'home'
      })
    })
    return {
      toHome
    }
  },
}

下面是整體頁面代碼
main.js

import { createApp } from 'vue'
import App from './App.vue'
import { router } from './route'

const app = createApp(App)
app.use(router)
app.mount('#app')

route下的index.js

import { createRouter, createWebHashHistory } from "vue-router"

const home = () => import("../home")
const login = () => import("../login")

const routes = [
  { path: "/", redirect: "/home" },
  {
    path: "/home",
    name: "home",
    component: home
  },
  {
    path: "/login",
    name: "login",
    component: login
  }
]

export const router = createRouter({
  history: createWebHashHistory(),
  routes: routes
})

login.vue

<template>
  <p>index</p>
  <button @click="toHome">toHome</button>
</template>
<script>
import { useRouter } from 'vue-router'
export default {
  setup () {
    const router = useRouter()
    const toHome = (() => {
      router.push({
        name: 'home'
      })
    })
    return {
      toHome
    }
  },
}
</script>
<style  scoped>
</style>

home.vue

<template>
  <p>home</p>
</template>
<script>
export default {

}
</script>
<style  scoped>
</style>
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末西采,一起剝皮案震驚了整個濱河市丧慈,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌删豺,老刑警劉巖,帶你破解...
    沈念sama閱讀 221,635評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異网沾,居然都是意外死亡,警方通過查閱死者的電腦和手機蕊爵,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,543評論 3 399
  • 文/潘曉璐 我一進店門辉哥,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人攒射,你說我怎么就攤上這事醋旦。” “怎么了会放?”我有些...
    開封第一講書人閱讀 168,083評論 0 360
  • 文/不壞的土叔 我叫張陵饲齐,是天一觀的道長。 經(jīng)常有香客問我咧最,道長捂人,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 59,640評論 1 296
  • 正文 為了忘掉前任矢沿,我火速辦了婚禮滥搭,結果婚禮上,老公的妹妹穿的比我還像新娘捣鲸。我一直安慰自己瑟匆,他們只是感情好,可當我...
    茶點故事閱讀 68,640評論 6 397
  • 文/花漫 我一把揭開白布栽惶。 她就那樣靜靜地躺著愁溜,像睡著了一般。 火紅的嫁衣襯著肌膚如雪媒役。 梳的紋絲不亂的頭發(fā)上祝谚,一...
    開封第一講書人閱讀 52,262評論 1 308
  • 那天,我揣著相機與錄音酣衷,去河邊找鬼交惯。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的席爽。 我是一名探鬼主播意荤,決...
    沈念sama閱讀 40,833評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼只锻!你這毒婦竟也來了玖像?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 39,736評論 0 276
  • 序言:老撾萬榮一對情侶失蹤齐饮,失蹤者是張志新(化名)和其女友劉穎捐寥,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體祖驱,經(jīng)...
    沈念sama閱讀 46,280評論 1 319
  • 正文 獨居荒郊野嶺守林人離奇死亡握恳,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 38,369評論 3 340
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了捺僻。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片乡洼。...
    茶點故事閱讀 40,503評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖匕坯,靈堂內的尸體忽然破棺而出束昵,到底是詐尸還是另有隱情,我是刑警寧澤葛峻,帶...
    沈念sama閱讀 36,185評論 5 350
  • 正文 年R本政府宣布锹雏,位于F島的核電站,受9級特大地震影響泞歉,放射性物質發(fā)生泄漏逼侦。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,870評論 3 333
  • 文/蒙蒙 一腰耙、第九天 我趴在偏房一處隱蔽的房頂上張望榛丢。 院中可真熱鬧,春花似錦挺庞、人聲如沸晰赞。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,340評論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽掖鱼。三九已至,卻和暖如春援制,著一層夾襖步出監(jiān)牢的瞬間戏挡,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,460評論 1 272
  • 我被黑心中介騙來泰國打工晨仑, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留褐墅,地道東北人拆檬。 一個月前我還...
    沈念sama閱讀 48,909評論 3 376
  • 正文 我出身青樓,卻偏偏與公主長得像妥凳,于是被迫代替她去往敵國和親竟贯。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 45,512評論 2 359