vue-router 路由和组件

本文涉及的产品
文档翻译,文档翻译 1千页
文本翻译,文本翻译 100万字符
图片翻译,图片翻译 100张
简介: vue-router 是 vue 中需要学习的一个重要部分, 下面我来与大家分享下自己的经验想了解更多组件的知识请看Vue 自定义组件以 饿了么APP 为例底部是我用 mint-ui 做成的公共组件, 取名为 "BottomTab"...

vue-router 是 vue 中需要学习的一个重要部分, 下面我来与大家分享下自己的经验

想了解更多组件的知识请看Vue 自定义组件

以 饿了么APP 为例
底部是我用 mint-ui 做成的公共组件, 取名为 "BottomTab"


首先我们来配置下公共组件 BottomTab, 代码如下 (mint-ui 引入需要单独配置, 这里不做详述)

<template>
    <mt-tabbar v-model="currentId" fixed>
        <mt-tab-item id="home">
            <!-- <img slot="icon" :src="[currentId == 'home' ? require('') : require('')]"> -->
            <img slot="icon" :src="currentId == 'home'">
            首页
        </mt-tab-item>
        <mt-tab-item id="discover">
            <!-- <img slot="icon" :src="[currentId == 'discover' ? require('') : require('')]"> -->
            <img slot="icon" :src="currentId == 'discover'">
            发现
        </mt-tab-item>
        <mt-tab-item id="order">
            <!-- <img slot="icon" :src="[currentId == 'order' ? require('') : require('')]"> -->
            <img slot="icon" :src="currentId == 'order'">
            订单
        </mt-tab-item>
        <mt-tab-item id="profile">
            <!-- <img slot="icon" :src="[currentId == 'profile' ? require('') : require('')]"> -->
            <img slot="icon" :src="currentId == 'profile'">
            我的
        </mt-tab-item>
    </mt-tabbar>
</template>

<script>
export default {
    name: "BottomTab",
    data() {
        return {
            currentId: "home"
        }
    },
    watch: {
        // 实现路由跳转
        currentId: function(val, oldVal) {
            this.$router.push("/" + val);
        }
    }
};
</script>

创建完组件之后, 接下来就是要将它引入到相应的页面中了
首先创建一个文件 main.vue 做为所有页面的主路由, 各个页面的公共模块都放在这个文件里面
然后将底部的公共组件引用到这个文件夹内, 组件首字母建议大写, 代码如下

<template>
    <div>
        <!-- 3. 在 template 中就可以直接使用了 -->
        <BottomTab></BottomTab>
    </div>
</template>

<script>
    // 1. 使用 import 导入想要引用的的子组件, 这里采用的是绝对路径
    import BottomTab from '@/components/common/BottomTab'

    export default {
        name: 'mainContent',
        components: {
            // 2. 在 components 中写入子组件
            BottomTab
        },
</script>

想实现路由之间相互跳转的话, 必须得先配置 router/index.js 文件
mainContent 为主路由; home discover order profile 为子路由, 对应跳转的四个页面, 代码如下

import Vue from 'vue'
import Router from 'vue-router'

// 主路由
const MainContent = resolve => require.ensure([], () => resolve(require('@/views/main.vue')), 'MainContent');

// 首页
const Home = resolve => require.ensure([], () => resolve(require('@/views/home/Home.vue')), 'Home'); // 首页

// 发现
const Discover = resolve => require.ensure([], () => resolve(require('@/views/discover/Discover.vue')), 'Discover'); // 发现

// 订单
const Order = resolve => require.ensure([], () => resolve(require('@/views/order/Order.vue')), 'Order'); // 订单

// 我的
const Profile = resolve => require.ensure([], () => resolve(require('@/views/profile/Profile.vue')), 'Profile'); // 我的

Vue.use(Router)

export default new Router({
    routes: [
        {
            path: '/',
            redirect: '/home' // 默认路径
        }, {
            //主路由
            path: '/main',
            name: 'mainContent',
            component: MainContent,
            children: [
                { 
                    // 首页
                    path: '/home',
                    name: 'home',
                    component: Home
                }, { 
                    // 发现
                    path: '/discover',
                    name: 'discover',
                    component: Discover
                }, { 
                    // 订单
                    path: '/order',
                    name: 'order',
                    component: Order
                }, { 
                    // 我的
                    path: '/profile',
                    name: 'profile',
                    component: Profile
                },
            ]
        },
    ]
})
  • router-view
    • 主要是构建 SPA (单页应用) 时,方便渲染你指定路由对应的组件。你可以 router-view 当做是一个容器,它渲染的组件是你使用 vue-router 指定的

路由配置完成后, 就要使用 router-view 进行渲染了 (只要有子路由, 就要用它来渲染)
进入前面创建好的文件 main.vue内, 代码如下

<template>
    <div>
        <BottomTab></BottomTab>
        <div class="main-content">
            <router-view></router-view>
        </div>
    </div>
</template>

然后进入页面看一下效果, 是否配置成功


相关文章
|
5天前
Vue3——基于tdesign封装一个通用的查询组件
Vue3——基于tdesign封装一个通用的查询组件
22 3
|
4天前
|
数据可视化 JavaScript
Vue3项目使用G6可视化组件实现一个树形机构图
在Vue 3项目中使用G6可视化组件库实现树形机构图的构建和展示。
30 1
Vue3项目使用G6可视化组件实现一个树形机构图
|
9天前
|
JavaScript 前端开发 API
【Vue 3】一个小巧玲珑的 Vue 组件切换动画库,开源且免费!!
【Vue 3】一个小巧玲珑的 Vue 组件切换动画库,开源且免费!!
【Vue 3】一个小巧玲珑的 Vue 组件切换动画库,开源且免费!!
|
9天前
|
JavaScript 前端开发 搜索推荐
Vue 路由的hash模式和history模式有什么区别?
在Vue.js框架中,路由管理是单页面应用(SPA)不可或缺的功能。Vue 路由提供了两种模式:hash模式和history模式,这两种模式主要负责处理URL的变更而无需重新加载整个页面,实现前端路由的功能。
53 19
|
3天前
|
JavaScript
在Vue中使用Swiper轮播图、同时解决点击轮播图左右切换按钮不生效的问题、同时将轮播图抽离出为一个公共组件
这篇文章介绍了在Vue中如何使用Swiper插件创建轮播图,解决Swiper左右切换按钮不生效的问题,并展示了如何将Swiper轮播图抽离成一个可复用的公共组件,同时提供了详细的安装、配置和优化建议。
在Vue中使用Swiper轮播图、同时解决点击轮播图左右切换按钮不生效的问题、同时将轮播图抽离出为一个公共组件
|
4天前
|
JavaScript 容器
Vue学习之--------组件在Vue脚手架中的使用(代码实现)(2022/7/24)
这篇文章通过代码示例和项目目录结构图,介绍了如何在Vue脚手架中使用组件来实现一个产品列表页。文章详细展示了组件的编写、引入、注册和使用步骤,并提供了实际效果截图。同时,文章还友情提示读者需要使用Vue脚手架来完成这些操作。
Vue学习之--------组件在Vue脚手架中的使用(代码实现)(2022/7/24)
|
4天前
|
JavaScript 程序员
Vue学习之--------组件嵌套以及VueComponent的讲解(代码实现)(2022/7/23)
这篇文章通过代码示例和效果图,详细阐述了Vue中组件的嵌套使用,包括创建组件、组件间的嵌套、注册组件以及实现的效果。同时,文章还介绍了VueComponent的相关知识,包括组件实例对象和Vue实例对象的区别。
Vue学习之--------组件嵌套以及VueComponent的讲解(代码实现)(2022/7/23)
|
4天前
|
JavaScript 容器
Vue学习之--------组件的基本使用(非单文件组件)(代码实现)(2022/7/22)
这篇文章讲解了Vue中组件的基本使用方法,包括组件的定义、注册和使用过程,并通过代码实例演示了非单文件组件的创建和使用,同时指出了一些使用组件时的注意事项。
Vue学习之--------组件的基本使用(非单文件组件)(代码实现)(2022/7/22)
|
4天前
|
JavaScript
Vue中router路由的使用、router-link的使用(在项目中的实际运用方式)
这篇文章介绍了Vue中router路由和router-link的使用方式,包括router配置、router-link在模板中的使用,以及实现的导航菜单和页面路由效果。
Vue中router路由的使用、router-link的使用(在项目中的实际运用方式)
|
9天前
|
JavaScript API
【Vue 3】推荐 1 个简约且美丽的天气组件
【Vue 3】推荐 1 个简约且美丽的天气组件