【Vue基础】Vue路由,实现页面跳转

news2025/1/8 17:29:25

一、需求说明

点击不同的模块实现页面跳转,如下点击“员工管理”右侧会显示员工管理页面,如下图1;点击“入住信息”右侧会显示入住信息,如下图二

二、涉及文件

1、 主要上图在这几个文件中修改相关代码

2、知识点整理

1)Vue Router 是 Vue 的官方路由,其组成有:

VueRouter:路由器类,根据路由请求在路由视图中动态染选中的组件

<router-link>:请求链接组件,浏览器会解析成<a>

<router-view>:动态视图组件,用来染展示与路由路径对应的组件

三、代码参考

1、App.vue文件,动态展示组件

<template>
  <div >
    <!-- <h1>{{ message }}</h1> -->
    <!-- <element-view></element-view> -->
    <!--<emp-view></emp-view>-->
   <!-- <Btest2-view></Btest2-view>-->
   <router-view></router-view>
  </div>
</template>

<script>
//import empView from './views/systemTest/empView.vue'
//import Btest2View from './views/systemTest/Btest2View.vue'
//import ElementView from './views/element/ElementView.vue'
export default {
  //components: { empView },
  //components: { ElementView },
  components: { /*Btest2View*/ },
  data() {
    return {
      message: "Hello world!" 
    }
  },
  methods: {
    
  }
}
</script>

<style>

</style>

2、index.js文件,定义路由配置信息

import Vue from 'vue'
import VueRouter from 'vue-router'
//import HomeView from '../views/HomeView.vue'

Vue.use(VueRouter)

const routes = [
  {
    path: '/B1',
    name: 'Btest',
    component: () => import('../views/systemTest/BtestView.vue')
  },
  {
    path: '/B2',
    name: 'Btest2',
    // route level code-splitting
    // this generates a separate chunk (about.[hash].js) for this route
    // which is lazy-loaded when the route is visited.
    component: () => import('../views/systemTest/Btest2View.vue')
  },
  {
    path: '/',
    redirect: '/B1'
  }
]

const router = new VueRouter({
  routes
})

export default router

3、main.js,导入路由信息,指定路由

import Vue from 'vue'
import App from './App.vue'
import router from './router'
//引入elementUI组件
import 'element-ui/lib/theme-chalk/index.css';
import ElementUI from 'element-ui';
//引入axios
import axios from 'axios'
//使用axios
Vue.prototype.axios=axios

Vue.config.productionTip = false
Vue.use(ElementUI);

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

4、请求链接组件

1)BtestView.vue文件

<template>
    <div>
        <el-container style="height: 800px; border: 1px solid #eee">
            <el-header style="font-size: 40px;background-color: rgb(238, 241, 246)">智能学习辅助系统</el-header>

            <el-container>
                <el-aside width="230px" style=" border: 1px solid #eee">
                    <!-- 目录</el-aside> -->
                    <!-- <br> -->
                    <el-menu :default-openeds="['1', '3']">
                    <el-submenu index="1">
                        <template slot="title"><i class="el-icon-message"></i>系统信息管理</template>
                        <el-menu-item-group>
                        <template slot="title">人力资源</template>
                        <el-submenu index="1-1">
                        <template slot="title">
                            <router-link to="/B1">员工管理</router-link>
                        </template>
                        <el-menu-item index="1-1-1">模块1</el-menu-item>
                        <el-menu-item index="1-1-2">模块2</el-menu-item>
                        </el-submenu>
                        <el-menu-item index="1-2">
                            <router-link to="/B2">入住信息</router-link>
                        </el-menu-item>                           
                        </el-menu-item-group> 
                    </el-submenu>            
                <el-submenu index="2">
                        <template slot="title"><i class="el-icon-menu"></i>销售产品</template>
                        <el-menu-item-group>
                        <template slot="title">产品1</template>
                        <el-menu-item index="2-1">产品2</el-menu-item>        
                        </el-menu-item-group>           
                    </el-submenu>        
                    </el-menu>
                </el-aside> 
        
            <el-main>
                <!--表单,可输入查询条件-->
                <el-form :inline="true" :model="searchForm" class="demo-form-inline">
                <el-form-item label="姓名">
                    <el-input v-model="searchForm.name" placeholder="谢逊"></el-input>
                </el-form-item>
                <el-form-item label="性别">
                    <el-select v-model="searchForm.source" placeholder="男">
                    <el-option label="男" value="1"></el-option>
                    <el-option label="女" value="2"></el-option>
                    </el-select>
                </el-form-item>           
                <el-form-item label="入职日期">
                    <!--日期选择-->
                    <el-date-picker
                    v-model="searchForm.TTM"
                    type="daterange"
                    range-separator="至"
                    start-placeholder="开始日期"
                    end-placeholder="结束日期">
                    </el-date-picker>                       
                </el-form-item>
                <el-form-item>
                    <el-button type="primary" @click="onSubmit">查询</el-button>
                </el-form-item>
                </el-form>

                <!--表格-->
                <el-table :data="tableData" border >
                <el-table-column prop="name" label="姓名" width="140">
                </el-table-column>
                <el-table-column  label="图像" width="120">
                    <template slot-scope="scope">
                        <img :src="scope.row.image" width="90px" height="70px">
                        <!-- <img :src="homeIcon"> -->
                    </template>
                </el-table-column>
                <el-table-column  label="性别" width="120">
                    <template slot-scope="scope">
                        {{ scope.row.gender==1?'男':'女' }}
                    </template>   
                </el-table-column>
                <el-table-column prop="job" label="职称" width="120">
                </el-table-column>
                <el-table-column prop="entrydate" label="入职日期" width="140">
                </el-table-column>
                <el-table-column prop="updatetime" label="上市时间" width="140">
                </el-table-column>
                <el-table-column label="操作">
                    <el-button type="primary" size="mini">编辑</el-button>
                    <el-button type="danger" size="mini">删除</el-button>
                </el-table-column>
                </el-table>
                <br>
             
      <!--页码-->
            <el-pagination background  layout="total, sizes, prev, pager, next"
                @size-change="handleSizeChange"
                @current-change="handleCurrentChange"
                :total="100">
            </el-pagination>
            </el-main>
            </el-container>
        </el-container>

        <!-- <img v-bind:src="craftWool.json.image" alt="" /> -->
        <!-- <img :src=" require('@/assets/craftWool/'+img)" alt=""> -->
        <!-- <img src="../../桂花兔.jpg\" alt="\"> -->


    </div>

</template>
<script>
import axios from 'axios';
//import { Scope } from 'eslint-scope';
//let imgs= require('@/public/craftWool.json')
//console.img(imgs);
//var img = require('/test01/src/assets/craftWool/桂花兔.jpg');
//console.log(img);
//import homeIcon from '@/assets/craftWool/桂花兔.jpg'


export default {
    data(){
        return {
        tableData: [],
        searchForm:{
            name:"",
            gender:"",
            entrydate:[]
        },
        //img:imgs.url
      }
    },
    methods: {
        onSubmit:function(){

        },
        handleSizeChange:function(val) {
            console.log(`每页 ${val} 条`);
            alert("每页记录数变化"+val)
        },
        handleCurrentChange:function(val) {
            console.log(`当前页: ${val}`);
            alert("页码变化"+val)
        }
    },
    mounted() {
        //发送异步请求,获取数据
        //axios.get("//test01/src/jsonData/craftWool.json").then((result)=>{//出错,多了“/”
        axios.get("http://yapi.smart-xwork.cn/mock/169327/emp/list").then((result)=>{//教程参考表格链接
        //axios.get("/test01/public/craftWool.json").then((result)=>{
            //成功回调
            this.tableData=result.data.data;
            //this.image = result.data.image;
            //this.img=result.img.image;
        });

    }
}
</script>
<style scoped>

</style>

2)Btest2View.vue文件

<template>
    <div>
        <el-container style="height: 800px; border: 1px solid #eee">
            <el-header style="font-size: 40px;background-color: rgb(238, 241, 246)">智能学习辅助系统</el-header>

            <el-container>
                <el-aside width="230px" style=" border: 1px solid #eee">
                    <!-- 目录</el-aside> -->
                    <!-- <br> -->
                    <el-menu :default-openeds="['1', '3']">
                    <el-submenu index="1">
                        <template slot="title"><i class="el-icon-message"></i>系统信息管理</template>
                        <el-menu-item-group>
                        <template slot="title">人力资源</template>
                        <el-submenu index="1-1">
                        <template slot="title">
                            <router-link to="/B1">员工管理</router-link>
                        </template>
                        <el-menu-item index="1-1-1">模块1</el-menu-item>
                        <el-menu-item index="1-1-2">模块2</el-menu-item>
                        </el-submenu>
                        <el-menu-item index="1-2">
                            <router-link to="/B2">入住信息</router-link>
                        </el-menu-item>                           
                        </el-menu-item-group> 
                    </el-submenu>            
                <el-submenu index="2">
                        <template slot="title"><i class="el-icon-menu"></i>销售产品</template>
                        <el-menu-item-group>
                        <template slot="title">产品1</template>
                        <el-menu-item index="2-1">产品2</el-menu-item>        
                        </el-menu-item-group>           
                    </el-submenu>        
                    </el-menu>
                </el-aside> 
        
            <el-main>
                <el-table
                :data="tableData"
                stripe
                style="width: 100%">
                <el-table-column
                
                prop="date"
                label="入住日期"
                width="180">
                </el-table-column>
                <el-table-column
                
                prop="name"
                label="姓名"
                width="180">
                </el-table-column>
                <el-table-column
                
                prop="address"
                label="地址">
                </el-table-column>
                
            </el-table>
            </el-main>
            </el-container>
        </el-container>

        <!-- <img v-bind:src="craftWool.json.image" alt="" /> -->
        <!-- <img :src=" require('@/assets/craftWool/'+img)" alt=""> -->
        <!-- <img src="../../桂花兔.jpg\" alt="\"> -->


    </div>

</template>
<script>
//import axios from 'axios';
//import { Scope } from 'eslint-scope';
//let imgs= require('@/public/craftWool.json')
//console.img(imgs);
//var img = require('/test01/src/assets/craftWool/桂花兔.jpg');
//console.log(img);
//import homeIcon from '@/assets/craftWool/桂花兔.jpg'


export default {
    data(){
        return {
        //nameData: [],
        tableData: [{
          date: '2016-05-02',
          name: 'A',
          address: '上海市普陀区金沙江路 001 弄'
        }, {
          date: '2016-05-04',
          name:  'B',
          address: '上海市普陀区金沙江路 002 弄'
        }, {
          date: '2016-05-01',
          name:  'C',
          address: '上海市普陀区金沙江路 003 弄'
        }, {
          date: '2016-05-03',
          name:  'D',
          address: '上海市普陀区金沙江路 004 弄'
        }]
        
    }
    
    },
   
    methods: {
        onSubmit:function(){

        },
        handleSizeChange:function(val) {
            console.log(`每页 ${val} 条`);
            alert("每页记录数变化"+val)
        },
        handleCurrentChange:function(val) {
            console.log(`当前页: ${val}`);
            alert("页码变化"+val)
        }
    },
    mounted() {
        //发送异步请求,获取数据
        //axios.get("//test01/src/jsonData/craftWool.json").then((result)=>{//出错,多了“/”
       // axios.get("http://yapi.smart-xwork.cn/mock/169327/emp/list").then((result)=>{//教程参考表格链接
        //axios.get("/test01/public/craftWool.json").then((result)=>{
            //成功回调
           // this.nameData=result.data.data.name;
            //this.image = result.data.image;
            //this.img=result.img.image;
       // });

    }
}
</script>
<style scoped>

</style>

四、链接教程

1、Vue路由学习视频链接https://www.bilibili.com/video/BV1m84y1w7Tb?p=48&vd_source=841fee104972680a6cac4dbdbf144b50

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/558941.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

25K 入职腾讯的那天,我特么哭了

悲催的经历&#xff1a; 先说一下自己的个人情况&#xff0c;计算机专业&#xff0c;17 年本科毕业&#xff0c;一毕业就进入了“阿里”软件测试 岗(进去才知道是接了个阿里外包项目&#xff0c;可是刚毕业谁知道什么外包不外包的)。 更悲催的是&#xff1a;刚入职因为家里出…

工厂蓝牙定位技术的原理、应用场景、优势及潜在问题

蓝牙定位技术是近年来在工业领域中得到广泛应用的一项技术。随着工业自动化的快速发展和物联网技术的普及&#xff0c;工厂蓝牙定位成为了提高生产效率、优化生产流程和管理的重要工具。本文将详细介绍工厂蓝牙定位技术的原理、应用场景以及其在工业生产中的优势。 首先&#x…

redis集群读写,容错切换,从属调整,扩容,缩容

rediscluster 读写一定要注意redis实例的区间实例范围。需要路由到位。 比如 hashsolthash(k1) mod 1638412706,而12706槽位不在6391上&#xff0c;在6393上。 如何让rediscluster 路由到槽呢&#xff1f; redis-cli命令尾部加上 -c即可。防止路由失效。如果k1不在6391上&am…

企业如何将采购成本最小化?

从人员成本到运输和手续费&#xff0c;采购成本涵盖了广泛的费用&#xff0c;这些费用可能会迅速增加。这就是为什么要有一个明确的采购流程&#xff0c;鼓励竞争性招标&#xff0c;并使供应商轻松与你合作。但是&#xff0c;降低采购成本的最有效方法也许是通过实施一个采购软…

电力导线镭射光防外破预警系统

电力导线镭射光防外破预警系统 一、产品描述&#xff1a; 我司研发生产了一款型号为TLKS-PMG-WPI的电力导线镭射光防外破预警系统&#xff0c;是与电力设计时代发展升级的产品&#xff0c;在配电网需要实时在线监测的前景下&#xff0c;设备的稳定可靠性也是一种前所未有的挑战…

Linux 设备驱动程序(三)

系列文章目录 Linux 内核设计与实现 深入理解 Linux 内核&#xff08;一&#xff09; 深入理解 Linux 内核&#xff08;二&#xff09; Linux 设备驱动程序&#xff08;一&#xff09; Linux 设备驱动程序&#xff08;二&#xff09; Linux 设备驱动程序&#xff08;三&#xf…

WIN提权 令牌窃取进程注入

令牌窃取&#xff08;鸡肋玩意 2008包括2008以下&#xff09; 令牌&#xff0c;又叫token&#xff0c;是系统临时产生的秘钥&#xff0c;相当于账号密码&#xff0c;用来决定是否允许此次请求和判断此次请求是属于哪一个用户。 win7一下的版本可以尝试 这里使用msf上自带的令…

CCF-CSP 202006-1 线性分类器

根据高中知识我们知道&#xff0c;通过将点带入直线方程得到大于0或等于0或小于0&#xff0c;其中大于0与小于0的情况即对应两个点在直线的两边 据此&#xff0c;我们取最后一个输入的A点作为标准、最后一个输入的B点作为标准&#xff0c;记录下他们的>0还是<0&#xff0…

市面上常见的语音芯片的IO口有哪些作用

语音芯片的IO口有哪些作用&#xff1f; 语音芯片的IO口一般有多种用途&#xff0c;包括以下几种&#xff1a; 1. 语音输入&#xff1a;可以通过外部麦克风接口&#xff0c;将外部声音信号输入到语音芯片中&#xff0c;进行语音信号处理。 2. 语音输出&#xff1a;语音芯片可…

UTP网络编程入门案例

说明&#xff1a;UTP是面向无连接的&#xff0c;不可靠的协议&#xff0c;即传输数据时不会确定对方是否在线&#xff0c;优点是效率高。 DatagramSocket & DatagramPacket DatagramSocket是使用UDP协议的Socket&#xff0c;它的作用是接收和发送数据包&#xff1b; Dat…

数字信号处理6

昨天简单的复习了一下离散时间信号是什么以及系统的概念、系统要做的工作和系统中几个简单的原件&#xff0c;今天跟着昨天的内容继续学习。 一、离散时间系统的分类&#xff1a; 为什么要对系统进行分类呢&#xff0c;这就像是我们对函数进行分类一样&#xff0c;有些函数有…

提供免费样机模板素材的好网站推荐

说到原型样机模板&#xff0c;设计师当然并不陌生&#xff0c;因为经常在设计师完成作品后&#xff0c;为了更好地展示作品&#xff0c;通常将设计作品应用于真正的原型样机模板&#xff0c;可以快速在现实场景中展示设计作品&#xff0c;选择好的原型样机模板&#xff0c;操作…

超低功耗SUB 1G无线收发芯片+32位 Soc芯片UM2080F32 无线集抄/测温/养老院人员定位

UM2080F32是一款超低功耗 32 位 IoTP&#xff1a;ARMCortex-M0&#xff0c;64KB Flash&#xff0c;16KB SRAM&#xff0c;Sub-1GHz 射频收发器。工作于200MHz~960MHz 范围内。 UM2080F32 内部还集成了 CAN、12 位 SAR ADC、UART、SPI、QSPI、I2C 等通用外围通讯接口&#xff0c…

网络管理。

简介 网络接口名称规则 ls /etc/sysconfig/network-scripts/ -a NetworkManager服务 网络管理器是一个动态网络的控制器与配置系统&#xff0c;它用于当网络设备可用时保持设备和连接开启并激活默认情况下&#xff0c;CentOs/RHEL 7已安装网络管理器&#xff0c;并处于启用状态…

【Java this关键字】如何使用以及注意点 访问成员变量,访问成员方法,构造方法内调用构造方法

欢迎收看本篇文章 介绍 Java this 关键字的使用以及某些注意点 欢迎oomsday点踩&#xff0c;欢迎其他人点赞 &#x1f60b; Java this关键字 ⭐ this 关键字的作用⭐ this 注意点⭐ this 用法访问成员变量访问成员方法在构造方法内调用构造方法 ⭐ this 关键字的作用 在 Java …

C10K-C10M进阶(高并发的真正理解)

1、一台计算机可以连接的TCP受什么限制&#xff1f; 能打开文件描述符的限制。默认是1024&#xff0c;可以修改。 端口号的限制&#xff0c;65535&#xff0c;因为TCP头部16位的端口号&#xff0c;其中1024以上可以用。如果是客户端&#xff0c;最多可以打开6万多的文件。如果是…

车载测试之车联网OTA安全实践

在SDV的大趋势下&#xff0c;汽车零部件智能化水平不断提高&#xff0c;车辆内部搭载的软件也越来越多。毫无疑问&#xff0c;车辆复杂度的提高必将带来维护上的困难&#xff0c;车企要如何面对更新迭代速度越来越快的软件、固件系统&#xff1f;OTA&#xff08;over the air&a…

论文笔记: Trajectory Clustering: A Partition-and-Group Framework

07 Sigmoid 使用类DBSCAN的思路对轨迹聚类 1 intro 1.1 轨迹聚类 现有的轨迹聚类算法是将相似的轨迹作为一个整体进行聚类&#xff0c;从而发现共同的轨迹。 但是这样容易错过一些共同的子轨迹&#xff08;sub-trajectories&#xff09;。而在实际中&#xff0c;当我们对特…

运行 100 万个并发任务需要多少内存?

在这篇博文中&#xff0c;我深入研究了 Rust、Go、Java、C#、Python、Node.js 和 Elixir 等流行语言在异步和多线程编程之间的内存消耗比较。 前段时间&#xff0c;我不得不比较一些旨在处理大量网络连接的计算机程序的性能。我看到这些程序的内存消耗存在巨大差异&#xff0c…

【Atlas200】华为AIPP配置文件使用

目录 AIPP介绍图像处理顺序例子&#xff1a;YUV420SP_U8转BGR格式归一化配置对应公式crop及padding功能配置生效AIPP转换模板 AIPP介绍 华为的AIPP&#xff08;AI Preprocessing&#xff09;是一种面向AI应用的图像预处理技术&#xff0c;旨在提高AI应用的效率和精度。AIPP支持…