VueRouter之HelloWorld

添加包依赖

javascript 复制代码
  "dependencies": {
    "vue": "^2.7.7",
    "vue-router": "^3.5.4"
  },

Vue2对应VueRouter3

Vue3对应VueRouter4

在src/router/index.js中配置路由

javascript 复制代码
import Vue from 'vue'
import VueRouter from 'vue-router'

Vue.use(VueRouter)

const router = new VueRouter({
    mode: 'history',
    base: import.meta.env.BASE_URL,
    routes: [
        {
        },

    ]
})

export default router

在main.js中引入router

javascript 复制代码
import Vue from 'vue'

import App from './App.vue'
import router from './router'


new Vue({
  router,
  render: (h) => h(App)
}).$mount('#app')

我们做一个简单的案例

点击首页、关于,调到对应的组件

目录结构如下

App.vue

html 复制代码
<script setup>
</script>

<template>
  <div class="app-container">
    <h1>App根组件</h1>
    <router-link to="/home">首页</router-link>
    <router-link to="/about">关于</router-link>
    <hr>
    <router-view></router-view>
  </div>
</template>

<style scoped>
.app-container {
  text-align: center;
  font-size: 16px;
}

.app-container a {
  padding: 10px;
  color: #000;
}

.app-container a.routerr-link-active {
  color: #fff;
  background-color: #000;
}
</style>

HomeView.vue

html 复制代码
<script>
export default {
  name: "HomeView"
}
</script>

<template>
  <div class="home-container">
    <h3>Home组件</h3>
  </div>

</template>

<style scoped>
.home-container {
  min-height: 150px;
  background-color: #f2f2f2;
  padding: 15px;
}

</style>

AboutView.vue

html 复制代码
<script>
export default {
  name: "AboutView"
}
</script>

<template>
  <div class="about-container">
    <h3>About组件</h3>
  </div>

</template>

<style scoped>
.about-container {
  min-height: 150px;
  background-color: #f2f2f2;
  padding: 15px;
}

</style>

index.js

javascript 复制代码
import Vue from 'vue'
import VueRouter from 'vue-router'

Vue.use(VueRouter)

const router = new VueRouter({
    mode: 'history',
    base: import.meta.env.BASE_URL,
    routes: [
        {
            path: '/',
            redirect: '/home'
        },
        {
            path: '/home',
            name: 'home',
            component: () => import('../views/HomeView.vue')
        },
        {
            path: '/about',
            name: 'about',
            component: () => import('../views/AboutView.vue')
        },

    ]
})

export default router
相关推荐
m0_748233171 分钟前
Laravel+Vue:全栈开发终极指南
vue.js·php·laravel
雨季6662 分钟前
Flutter 三端应用实战:OpenHarmony “呼吸灯”——在焦虑时代守护每一次呼吸的数字禅修
开发语言·前端·flutter·ui·交互
切糕师学AI3 分钟前
Vue 中如何修改地址栏参数并重新加载?
前端·javascript·vue.js
软弹3 分钟前
Vue3如何融合TS
前端·javascript·vue.js
2501_920931707 小时前
React Native鸿蒙跨平台采用ScrollView的horizontal属性实现横向滚动实现特色游戏轮播和分类导航
javascript·react native·react.js·游戏·ecmascript·harmonyos
0思必得08 小时前
[Web自动化] Selenium处理动态网页
前端·爬虫·python·selenium·自动化
东东5169 小时前
智能社区管理系统的设计与实现ssm+vue
前端·javascript·vue.js·毕业设计·毕设
catino9 小时前
图片、文件的预览
前端·javascript
2501_9209317010 小时前
React Native鸿蒙跨平台实现推箱子游戏,完成玩家移动与箱子推动,当所有箱子都被推到目标位置时,玩家获胜
javascript·react native·react.js·游戏·ecmascript·harmonyos
layman052811 小时前
webpack5 css-loader:从基础到原理
前端·css·webpack