Vue基础(前端教程①-路由)

项目结构

复制代码
src/
  ├── router/
  │    └── index.js       # 路由配置
  ├── components/
  │    ├── Home.vue       # 首页组件
  │    ├── About.vue      # 关于页组件
  │    └── Contact.vue    # 联系页组件
  ├── App.vue             # 根组件(含导航栏)
  └── main.js             # 入口文件

1. 路由配置文件 router/index.js

复制代码
import { createRouter, createWebHistory } from 'vue-router'
import Home from '../components/Home.vue'
import About from '../components/About.vue'
import Contact from '../components/Contact.vue'

const routes = [
  { path: '/', name: 'Home', component: Home },
  { path: '/about', name: 'About', component: About },
  { path: '/contact', name: 'Contact', component: Contact }
]

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

export default router

2. 组件文件 components/

Home.vue
复制代码
<template>
  <div class="page-container">
    <h1>首页</h1>
    <p>欢迎访问我们的网站!</p>
    <button @click="greet">点击打招呼</button>
  </div>
</template>

<script>
export default {
  name: 'Home',
  methods: {
    greet() {
      alert('Hello!')
    }
  }
}
</script>

<style scoped>
.page-container {
  padding: 20px;
}
</style>

3. 根组件 App.vue

复制代码
<template>
  <div id="app">
    <!-- 导航栏 -->
    <nav class="navbar">
      <router-link to="/" class="nav-link">首页</router-link>
      <router-link to="/about" class="nav-link">关于</router-link>
      <router-link to="/contact" class="nav-link">联系</router-link>
    </nav>
    
    <!-- 路由出口:显示当前页面 -->
    <router-view />
  </div>
</template>

<script>
export default {
  name: 'App'
}
</script>

<style>
#app {
  font-family: Avenir, Helvetica, Arial, sans-serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-align: center;
  margin-top: 50px;
}

.navbar {
  background-color: #f8f9fa;
  padding: 10px 0;
  margin-bottom: 20px;
}

.nav-link {
  margin: 0 15px;
  text-decoration: none;
  color: #333;
  font-weight: 500;
}

.nav-link.router-link-exact-active {
  color: #42b983;
  border-bottom: 2px solid #42b983;
  padding-bottom: 2px;
}
</style>

4. 入口文件 main.js

复制代码
import { createApp } from 'vue'
import App from './App.vue'
import router from './router'

// 创建应用并使用路由
createApp(App)
  .use(router)
  .mount('#app')

所有需要在整个应用中生效的功能(如路由、全局样式、插件),都需要在 main.js 中通过 app.use()app.component() 等方法 "启用",否则无法在应用中全局使用。

main.js 是 Vue 应用的 "全局配置中心",负责告诉应用:"哪些资源是全局可用的,如何启动整个应用"。但它本身不是全局变量的容器,而是控制全局行为的入口。

相关推荐
亿元程序员1 分钟前
你知道三国志战略版是怎么实现横竖屏动态切换的吗?
前端
BD_Marathon3 分钟前
Vue3_双向绑定
前端·javascript·vue.js
霍理迪12 分钟前
CSS复合、关系、属性、伪类选择器
前端·javascript·css
棒棒的唐14 分钟前
Avue2图片上传使用object对象模式时,axios的请求模式用post还是get?
开发语言·前端·javascript·avue
OnlyEasyCode18 分钟前
Linux部署Nginx前后端web教程
linux·前端·nginx
梵得儿SHI20 分钟前
Vue Router 路由管理从入门到精通:基础、导航与参数传递实战(含避坑指南)
前端·javascript·vue.js·路由基础配置·版本适配·路由实例创建·路由规则定义
IT_陈寒22 分钟前
JavaScript 性能优化实战:7 个让你的应用提速 50%+ 的 V8 引擎技巧
前端·人工智能·后端
Watermelo61723 分钟前
【前端实战】Axios 错误处理的设计与进阶封装,实现网络层面的数据与状态解耦
前端·javascript·网络·vue.js·网络协议·性能优化·用户体验
不一样的少年_24 分钟前
【性能监控】别只做工具人了!手把手带你写一个前端性能检测SDK
前端·javascript·监控
开发者小天24 分钟前
react中使用复制的功能
前端·javascript·react.js