• 结合Mockjs与Bus事件总线搭建首页导航和左侧菜单



    )

    一、前言

    Mock.js 是一个前端开发中常用的模拟数据生成工具。使用 Mock.js 可以方便地在前端开发过程中模拟后端接口返回的数据,从而实现前后端分离、并行开发。

    以下是一些使用 Mock.js 的好处:

    模拟后端接口:在前端开发过程中,有时后端接口可能尚未完成或者无法访问,这时可以使用 Mock.js 来模拟后端接口返回的数据。通过定义模拟数据的规则和结构,可以快速生成符合预期的假数据,使前端能够独立进行开发和调试,提高开发效率。

    快速生成测试数据:在进行功能测试和性能测试时,经常需要大量的测试数据。使用 Mock.js 可以方便地生成各种类型、格式的测试数据,满足测试需求。同时,Mock.js 还支持生成随机数据,可以模拟真实环境下的各种数据情况,提高测试的全面性和可靠性。

    数据格式多样化:Mock.js 提供了丰富的数据模板语法,可以根据需要生成不同格式的数据,如数字、字符串、日期、布尔值等。还可以通过正则表达式定义数据的格式和校验规则,方便地生成符合要求的数据。

    可扩展性强:Mock.js 提供了插件机制,可以根据自己的需求扩展更多功能。例如,可以定义接口延迟时间、模拟网络错误等,以模拟真实环境下的各种情况。

    总之,使用 Mock.js 可以提高前端开发效率,减少对后端依赖,同时也方便进行功能测试和性能测试。它是一个非常实用的工具,广泛应用于前端开发中。

    二、Mock.js的使用

    2.2.安装与配置

    npm i mockjs -D

    2.2.引入Mock.js

    • dev.env.js
    module.exports = merge(prodEnv, {
      NODE_ENV: '"development"',
    	MOCK: 'true'
    })
    
    • 1
    • 2
    • 3
    • 4
    • prod.env.js
    module.exports = {
      NODE_ENV: '"production"',
    	MOCK: 'false'
    }
    
    • 1
    • 2
    • 3
    • 4
    • main.js
    //开发环境下才会引入mockjs
    process.env.MOCK && require('@/mock') 
    
    • 1
    • 2

    2.4.Mock.js的使用

    login-mock.js
    模拟数据

    // const loginInfo = {
    // 	code: -1,
    // 	message: '密码错误'
    // }
    
    //使用mockjs的模板生成随机数据
    
    	
    	
    const loginInfo = {
    	'code|-1-0': 0,
    	'message|3-10': 'msg'
    }
    export default loginInfo;
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15

    index.js

    import Vue from 'vue'
    import Router from 'vue-router'
    import HelloWorld from '@/components/HelloWorld'
    import AppMain from '@/components/AppMain'
    import LeftNav from '@/components/LeftNav'
    import TopNav from '@/components/TopNav'
    import login from '@/views/login'
    import register from '@/views/register'
    
    
    
    
    Vue.use(Router)
    
    export default new Router({
      routes: [
        {
          path: '/',
          name: 'login',
          component: login
        },
    	{
    	  path: '/register',
    	  name: 'register',
    	  component: register
    	},
    	{
    	  path: '/AppMain',
    	  name: 'AppMain',
    	  component: AppMain
    	},{
    	  path: '/LeftNav',
    	  name: 'LeftNav',
    	  component: LeftNav
    	},{
    	  path: '/TopNav',
    	  name: 'TopNav',
    	  component: TopNav
    	},
      ]
    })
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41

    login.vue

    <template>
    	<div class="login-wrap">
    		<el-form class="login-container">
    			<h1 class="title">用户登录h1>
    			<el-form-item label="">
    				<el-input type="text" v-model="username" placeholder="登录账号" autocomplete="off">el-input>
    			el-form-item>
    			<el-form-item la-0bel="">
    				<el-input type="password" v-model="password" placeholder="登录密码" autocomplete="off">el-input>
    			el-form-item>
    			<el-form-item>
    				<el-button type="primary" style="width:100%;" @click="doSubmit()">提交el-button>
    			el-form-item>
    			<el-row style="text-align: center;margin-top:-10px">
    				<el-link type="primary">忘记密码el-link>
    				<el-link type="primary" @click="gotoRegister()">用户注册el-link>
    			el-row>
    		el-form>
    	div>
    template>
    
    <script>
    	// import axios from 'axios'
    	//    import qs from 'qs'
    
    	export default {
    		name: 'login',
    		data() {
    			return {
    				username: '',
    				password: ''
    			}
    		},
    		methods: {
    			gotoRegister() {
    				this.$router.push('/register');
    			},
    			doSubmit() {
    			           let url = this.axios.urls.SYSTEM_USER_DOLOGIN;
    			           let params = {
    			             username: this.username,
    			             password: this.password
    			           }
    			           this.axios.post(url, params).then(r => {
    			             console.log(r)
    			             // if (r.data.success) {
    			             //   this.$message({
    			             //     type: 'success',
    			             //     message: r.data.message
    			             //   });
    			             //   
    			             // }else{
    			             //   console.log(r)
    			             //   this.$message(r.data.message)
    			             // }
    			             this.$message({
    			               message:r.data.message,
    			               type:r.data.code ==0?'success':'error'
    			             })
    						 this.$router.push('/AppMain');
    			           }).catch(e => {
    			
    			           })
    			         }
    		}
    	}
    script>
    
    <style scoped>
    	.login-wrap {
    		box-sizing: border-box;
    		width: 100%;
    		height: 100%;
    		padding-top: 10%;
    		background-image: url();
    		/* background-color: #112346; */
    		background-repeat: no-repeat;
    		background-position: center right;
    		background-size: 100%;
    	}
    
    	.login-container {
    		border-radius: 10px;
    		margin: 0px auto;
    		width: 350px;
    		padding: 30px 35px 15px 35px;
    		background: #fff;
    		border: 1px solid #eaeaea;
    		text-align: left;
    		box-shadow: 0 0 20px 2px rgba(0, 0, 0, 0.1);
    	}
    
    	.title {
    		margin: 0px auto 40px auto;
    		text-align: center;
    		color: #505458;
    	}
    style>
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
    • 50
    • 51
    • 52
    • 53
    • 54
    • 55
    • 56
    • 57
    • 58
    • 59
    • 60
    • 61
    • 62
    • 63
    • 64
    • 65
    • 66
    • 67
    • 68
    • 69
    • 70
    • 71
    • 72
    • 73
    • 74
    • 75
    • 76
    • 77
    • 78
    • 79
    • 80
    • 81
    • 82
    • 83
    • 84
    • 85
    • 86
    • 87
    • 88
    • 89
    • 90
    • 91
    • 92
    • 93
    • 94
    • 95
    • 96
    • 97
    • 98

    在这里插入图片描述

    三、Bus事物总线

    3.1.首页导航栏与左侧菜单搭建

    <template>
    	<el-container class="main-container">
    		<el-aside v-bind:class="asideClass">
    			<LeftNav>LeftNav>
    		el-aside>
    		<el-container>
    			<el-header class="main-header">
    				<TopNav>TopNav>
    			el-header>
    			<el-main class="main-center">Mainel-main>
    		el-container>
    	el-container>
    template>
    
    <script>
    	// 导入组件
    	import TopNav from '@/components/TopNav.vue'
    	import LeftNav from '@/components/LeftNav.vue'
    
    	// 导出模块
    		export default {
    		    components: {
    		      TopNav,LeftNav
    		    },data() {
    		      return {
    		        asideClass: "main-aside"
    		      }
    		    },
    			created() {
    			this.$root.Bus.$on('aaa',v=>{
    				this.asideClass=v ?'main-aside-collapsed':'main-aside';
    			});
    			}
    		  };
    script>
    <style scoped>
    	.main-container {
    		height: 100%;
    		width: 100%;
    		box-sizing: border-box;
    	}
    
    	.main-aside-collapsed {
    		/* 在CSS中,通过对某一样式声明! important ,可以更改默认的CSS样式优先级规则,使该条样式属性声明具有最高优先级 */
    		width: 64px !important;
    		height: 100%;
    		background-color: #334157;
    		margin: 0px;
    	}
    
    	.main-aside {
    		width: 240px !important;
    		height: 100%;
    		background-color: #334157;
    		margin: 0px;
    	}
    
    	.main-header,
    	.main-center {
    		padding: 0px;
    		border-left: 2px solid #333;
    	}
    style>
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
    • 50
    • 51
    • 52
    • 53
    • 54
    • 55
    • 56
    • 57
    • 58
    • 59
    • 60
    • 61
    • 62
    • 63
    • 64
    <template>
    	<el-menu default-active="2" class="el-menu-vertical-demo"  background-color="#334157"
    	 text-color="#fff" active-text-color="#ffd04b" :collapse="collapsed" >
    		
    		<div class="logobox">
    			<img class="logoimg" src="../assets/img/logo.png" alt="">
    		div>
    		<el-submenu index="1">
    			<template slot="title">
    				<i class="el-icon-location">i>
    				<span>导航一span>
    			template>
    			<el-menu-item-group>
    				<template slot="title">分组一template>
    				<el-menu-item index="1-1">选项1el-menu-item>
    				<el-menu-item index="1-2">选项2el-menu-item>
    			el-menu-item-group>
    			<el-menu-item-group title="分组2">
    				<el-menu-item index="1-3">选项3el-menu-item>
    			el-menu-item-group>
    			<el-submenu index="1-4">
    				<template slot="title">选项4template>
    				<el-menu-item index="1-4-1">选项1el-menu-item>
    			el-submenu>
    		el-submenu>
    		<el-menu-item index="2">
    			<i class="el-icon-menu">i>
    			<span slot="title">导航二span>
    		el-menu-item>
    		<el-menu-item index="3" disabled>
    			<i class="el-icon-document">i>
    			<span slot="title">导航三span>
    		el-menu-item>
    		<el-menu-item index="4">
    			<i class="el-icon-setting">i>
    			<span slot="title">导航四span>
    		el-menu-item>
    	el-menu>
    template>
    <script>
    	export default {
    		data(){
    			return{
    				collapsed:false
    			}
    		},
    		created() {
    		this.$root.Bus.$on('aaa',v=>{
    			this.collapsed=v;
    		});
    		}
    	}
    script>
    <style>
    	.el-menu-vertical-demo:not(.el-menu--collapse) {
    		width: 240px;
    		min-height: 400px;
    	}
    
    	.el-menu-vertical-demo:not(.el-menu--collapse) {
    		border: none;
    		text-align: left;
    	}
    
    	.el-menu-item-group__title {
    		padding: 0px;
    	}
    
    	.el-menu-bg {
    		background-color: #1f2d3d !important;
    	}
    
    	.el-menu {
    		border: none;
    	}
    
    	.logobox {
    		height: 40px;
    		line-height: 40px;
    		color: #9d9d9d;
    		font-size: 20px;
    		text-align: center;
    		padding: 20px 0px;
    	}
    
    	.logoimg {
    		height: 40px;
    	}
    style>
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
    • 50
    • 51
    • 52
    • 53
    • 54
    • 55
    • 56
    • 57
    • 58
    • 59
    • 60
    • 61
    • 62
    • 63
    • 64
    • 65
    • 66
    • 67
    • 68
    • 69
    • 70
    • 71
    • 72
    • 73
    • 74
    • 75
    • 76
    • 77
    • 78
    • 79
    • 80
    • 81
    • 82
    • 83
    • 84
    • 85
    • 86
    • 87
    • 88
    • 89
    • 90
    <template>
    	
    	<el-menu class="el-menu-demo" mode="horizontal" background-color="#334157" text-color="#fff" active-text-color="#fff">
    		<el-button class="buttonimg">
    			<img class="showimg" :src="collapsed?imgshow:imgsq" @click="doToggle()">
    		el-button>
    		<el-submenu index="2" class="submenu">
    			<template slot="title">超级管理员template>
    			<el-menu-item index="2-1">设置el-menu-item>
    			<el-menu-item index="2-2">个人中心el-menu-item>
    			<el-menu-item @click="exit()" index="2-3">退出el-menu-item>
    		el-submenu>
    	el-menu>
    template>
    
    <script>
    	export default {
    			data(){
    			  return{
    			    collapsed:false,
    	        imgshow:require('@/assets/img/show.png'),
    	         imgsq:require('@/assets/img/sq.png')
    			  }
    			}
    			,methods:{doToggle(){
    				this.collapsed=!this.collapsed;
    			    this.$root.Bus.$emit('aaa',this.collapsed);
    			},
    			exit(){
    				this.$router.push("/");
    			}
    		}
    }
    script>
    
    <style scoped>
    	.el-menu-vertical-demo:not(.el-menu--collapse) {
    		border: none;
    	}
    
    	.submenu {
    		float: right;
    	}
    
    	.buttonimg {
    		height: 60px;
    		background-color: transparent;
    		border: none;
    	}
    
    	.showimg {
    		width: 26px;
    		height: 26px;
    		position: absolute;
    		top: 17px;
    		left: 17px;
    	}
    
    	.showimg:active {
    		border: none;
    	}
    style>
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
    • 50
    • 51
    • 52
    • 53
    • 54
    • 55
    • 56
    • 57
    • 58
    • 59
    • 60
    • 61
    • 62
    • 63
    • 64
    • 65
    • 66
    • 67
    • 68
    • 69
    • 70
    • 71
    • 72
    • 73
    • 74
    • 75
    • 76
    • 77
    • 78
    • 79
    • 80
    • 81

    router

    
    import Vue from 'vue'
    import Router from 'vue-router'
    import HelloWorld from '@/components/HelloWorld'
    import AppMain from '@/components/AppMain'
    import LeftNav from '@/components/LeftNav'
    import TopNav from '@/components/TopNav'
    import login from '@/views/login'
    import register from '@/views/register'
    
    
    
    
    Vue.use(Router)
    
    export default new Router({
      routes: [
        {
          path: '/',
          name: 'login',
          component: login
        },
    	{
    	  path: '/register',
    	  name: 'register',
    	  component: register
    	},
    	{
    	  path: '/AppMain',
    	  name: 'AppMain',
    	  component: AppMain
    	},{
    	  path: '/LeftNav',
    	  name: 'LeftNav',
    	  component: LeftNav
    	},{
    	  path: '/TopNav',
    	  name: 'TopNav',
    	  component: TopNav
    	},
      ]
    })
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43

    main.js

    // The Vue build version to load with the `import` command
    // (runtime-only or standalone) has been set in webpack.base.conf with an alias.
    import Vue from 'vue'
    process.env.MOCK && require('@/mock') 
    // 新添加1
    import ElementUI from 'element-ui' 
    // 新添加2,避免后期打包样式不同,要放在import App from './App';之前 
    import 'element-ui/lib/theme-chalk/index.css' 
    import App from './App'
    import router from './router'
    
    Vue.config.productionTip = false
    import axios from '@/api/http'                 
    import VueAxios from 'vue-axios' 
    
    Vue.use(VueAxios,axios)
    Vue.use(ElementUI)   
    /* eslint-disable no-new */
    new Vue({
      el: '#app',
      router,
      data(){
    	return{
    		Bus:new Vue()
    	}  
      },
      components: { App },
      template: ''
    })
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30

    在这里插入图片描述

  • 相关阅读:
    基于STM32两轮自平衡小车系统设计与控制
    正火热的人机协作,优势揭晓!
    cpp随笔——浅谈右值引用,移动语义与完美转发
    请解释Java中的策略模式,并举例说明其应用场景和实现方式。请解释Java中的模板方法模式,并讨论其在实际项目中的应用。
    Postman —— postman的介绍和安装
    第二章 矩阵
    创建型模式-原型模式(五)
    html基础之块元素、行内元素、行内块元素
    推荐一款新的自动化测试框架:DrissionPage!
    Matlab如何导入Excel数据并进行FFT变换
  • 原文地址:https://blog.csdn.net/m0_74018330/article/details/133296624