• 关于ElementUI之首页导航与左侧菜单实现


    目录

    一.Mock

    1.1.什么是Mock.js

    1.2.特点

    1.3.安装与配置

    1.3.1. 安装mock.js

    1.3.2.引入mock.js

    1.4.mockjs使用

    1.4.1.定义测试数据文件

    1.4.2.mock拦截Ajax请求

    1.4.3.界面代码优化

    二.总线

    2.1.是什么

    2.2.前期准备

    2.3.配置组件与路由关系

    2.3.1. 配置组件

    2.3.2.配置路由关系

    展示效果:

             好啦今天到这了,希望能帮到你!!!


    一.Mock

    1.1.什么是Mock.js

    Mock.js是一个模拟数据生成器,用于生成随机数据、模拟请求响应等。它可以帮助前端开发人员在开发过程中模拟接口数据,减少对后端接口的依赖。Mock.js提供了丰富的数据模板语法,可以生成各种类型的随机数据,如数字、字符串、日期、布尔值、数组、对象等。同时,Mock.js还提供了拦截Ajax请求的功能,可以直接拦截请求并返回模拟数据,方便进行接口开发和测试。Mock.js在前端开发中被广泛应用,可以提高开发效率,方便进行调试和功能开发。

    1.2.特点

    Mock.js的主要特点包括以下几个方面:

    1. 随机数据生成:Mock.js提供了丰富的数据模板语法,可以生成各种类型的随机数据,包括数字、字符串、日期、布尔值、数组、对象等。这使得开发人员可以很方便地生成需要的测试数据,避免手动编写大量的假数据。

    2. 数据模板定义:Mock.js支持使用数据模板定义数据结构,通过预先定义的模板规则,可以生成符合预期的数据。模板定义灵活且易于修改,可以根据需求进行定制。

    3. 响应拦截与模拟:Mock.js可以拦截Ajax请求,模拟后端接口的响应数据,从而实现前端与后端的分离开发。开发人员无需真实的后端接口,即可进行功能开发和测试,减少了开发的依赖和耦合。

    4. 数据延迟与动态数据:Mock.js支持对模拟数据添加延迟和动态数据的配置。延迟可以模拟真实接口的网络延迟,以验证前端在异步请求中的处理能力。动态数据可以根据实际情况生成变化的数据,使模拟数据更加真实。

    5. 支持跨域请求:Mock.js支持跨域请求的拦截和模拟,方便前端开发人员在本地进行接口联调和测试,无需关注跨域限制。

    总之,Mock.js提供了一套简单、高效、实用的模拟数据生成方案,使前端开发人员能够更加轻松地进行接口开发和测试,提高开发效率和质量。

    1.3.安装与配置

    1.3.1. 安装mock.js

    Win+R输入cmd打开命令提示符,执行以下命令进行mock.js安装,如下:

    npm i mockjs -D

    注:-D表示只在开发环境中使用。

    package.json中有以下代码即安装成功,如下:

    安装完成之后,我们需要引入mock.js。

    1.3.2.引入mock.js

    为了只在开发环境使用mock,而打包到生产环境时自动不使用mock,我们可以在config目录中的dev.env.jsprod.env.js做一个配置,如下:

    • dev.env.js

    1. 'use strict'
    2. const merge = require('webpack-merge')
    3. const prodEnv = require('./prod.env')
    4. module.exports = merge(prodEnv, {
    5. NODE_ENV: '"development"',
    6. MOCK: 'true'
    7. })
    • prod.env.js

    1. 'use strict'
    2. module.exports = {
    3. NODE_ENV: '"production"',
    4. MOCK: 'false'
    5. }
    • main.js

    1. //开发环境下才会引入mockjs
    2. process.env.MOCK && require('@/mock')

    1.4.mockjs使用

    1.4.1.定义测试数据文件

    在src目录下新建一个mock包,在mock包下定义测试数据文件,目录如下:

     login-mock.js:

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

    1.4.2.mock拦截Ajax请求

    在src/mock目录下创建index.js,定义拦截路由配置,如下:

    index.js:

    1. import Mock from 'mockjs' //引入mockjs,npm已安装
    2. import action from '@/api/action' //引入请求地址
    3. //全局设置:设置所有ajax请求的超时时间,模拟网络传输耗时
    4. Mock.setup({
    5. // timeout: 400 //延时400s请求到数据
    6. timeout: 200 - 400 //延时200-400s请求到数据
    7. })
    8. //引登陆的测试数据,并添加至mockjs
    9. import loginInfo from '@/mock/json/login-mock.js'
    10. let s1 = action.getFullPath('SYSTEM_USER_DOLOGIN')
    11. Mock.mock(s1, "post", loginInfo)
    12. // Mock.mock(s1, /post|get/i, loginInfo)

    1.4.3.界面代码优化

    由于此次展示无需用到后端代码,所以博主就将昨天前后端交互用到的后端代码给备注了,换上了正常前后端分离开发所用的mock.js代码,如下:

    Login.vue:

    1. <template>
    2. <div id="app">
    3. <template>
    4. <div class="login-wrap">
    5. <el-form class="login-container">
    6. <h1 class="title">用户登录h1>
    7. <el-form-item label="">
    8. <el-input type="text" v-model="username" placeholder="登录账号" autocomplete="off">el-input>
    9. el-form-item>
    10. <el-form-item label="">
    11. <el-input type="password" v-model="password" placeholder="登录密码" autocomplete="off">el-input>
    12. el-form-item>
    13. <el-form-item>
    14. <el-button type="primary" style="width:100%;" @click="doSubmit()">提交el-button>
    15. el-form-item>
    16. <el-row style="text-align: center;margin-top:-10px">
    17. <el-link type="primary">忘记密码el-link>
    18. <el-link type="primary" @click="gotoRegister()">用户注册el-link>
    19. el-row>
    20. el-form>
    21. div>
    22. template>
    23. div>
    24. template>
    25. <script>
    26. import axios from 'axios'
    27. import qs from 'qs'
    28. export default {
    29. name: 'Login',
    30. data () {
    31. return {
    32. username:'',
    33. password:''
    34. }
    35. }
    36. ,methods:{
    37. gotoRegister(){
    38. // router-like相当于a
    39. // location.href 相当于this.$router.push
    40. this.$router.push('/Register');
    41. },
    42. doSubmit(){
    43. let url =this.axios.urls.SYSTEM_USER_DOLOGIN;
    44. let params ={
    45. username:this.username,
    46. password:this.password
    47. }
    48. // $.ajax then相当于success
    49. // axios.get(url,{params:params}).then(r=>{
    50. // console.log(r);
    51. // if(r.data.success){
    52. // this.$message({
    53. // message:r.data.msg,
    54. // type: 'success'
    55. // });
    56. // }else{
    57. // this.$message.error(r.data.msg);
    58. // }
    59. // }).cath(e=>{
    60. // })
    61. this.axios.post(url,params).then(r => {
    62. console.log(r);
    63. // //如果携带的参数数据跟后端数据对应正确,说明登入成功,提示
    64. // if (r.data.success) {
    65. // this.$message({
    66. // showClose: true,
    67. // message: r.data.msg,
    68. // type: 'success'
    69. // });
    70. // } else {
    71. // //如果携带的参数数据跟后端数据对应错误,说明登入失败,提示
    72. // this.$message.error(r.data.msg);
    73. // }
    74. this.$message({
    75. message: r.data.message,
    76. type: r.data.code == 0 ?'success' : 'error'
    77. });
    78. this.$router.push('/AppMain');
    79. }).catch(e => {
    80. console.log(e);
    81. });
    82. }
    83. }
    84. }
    85. script>
    86. <style scoped>
    87. .login-wrap {
    88. box-sizing: border-box;
    89. width: 100%;
    90. height: 100%;
    91. padding-top: 10%;
    92. background-image: url();
    93. /* background-color: #112346; */
    94. background-repeat: no-repeat;
    95. background-position: center right;
    96. background-size: 100%;
    97. }
    98. .login-container {
    99. border-radius: 10px;
    100. margin: 0px auto;
    101. width: 350px;
    102. padding: 30px 35px 15px 35px;
    103. background: #fff;
    104. border: 1px solid #eaeaea;
    105. text-align: left;
    106. box-shadow: 0 0 20px 2px rgba(0, 0, 0, 0.1);
    107. }
    108. .title {
    109. margin: 0px auto 40px auto;
    110. text-align: center;
    111. color: #505458;
    112. }
    113. style>

    二.总线

    2.1.是什么

    总线(Bus)是计算机系统中用于在各个组件之间传输数据和控制信号的通道。它是计算机内部各个组件之间进行通信和协调工作的重要桥梁。

    在计算机系统中,总线可分为多种类型,常见的包括数据总线、地址总线和控制总线:

    1. 数据总线(Data Bus):用于在计算机内部不同组件之间传输数据。数据总线的位宽决定了一次可以传输的数据量,例如32位数据总线表示每次可以传输32位的数据。

    2. 地址总线(Address Bus):用于在计算机内部传输内存或者外设的地址信息。地址总线的位宽决定了CPU能够寻址的地址空间大小。

    3. 控制总线(Control Bus):用于传输各种控制信号,如读写控制、时钟信号、中断信号等。控制总线是计算机内部各个组件之间进行协调和控制的重要媒介。

    总线的设计和规划对于计算机系统的性能和功能有着重要影响。不同类型的总线在计算机内部承担不同的功能和作用,通过总线的高效运作,各个组件能够有效地进行数据传输和协同工作,实现计算机的功能和任务。

    2.2.前期准备

    依需用到案例展示,我们需要用到三个组件和部分图片搭建页面,如下:

    三个组件分别如下:

    AppMain.vue:

    1. <template>
    2. <el-container class="main-container">
    3. <el-aside v-bind:class="asideClass">
    4. <LeftNav>LeftNav>
    5. el-aside>
    6. <el-container>
    7. <el-header class="main-header">
    8. <TopNav>TopNav>
    9. el-header>
    10. <el-main class="main-center">Mainel-main>
    11. el-container>
    12. el-container>
    13. template>
    14. <script>
    15. // 导入组件
    16. import TopNav from '@/components/TopNav.vue'
    17. import LeftNav from '@/components/LeftNav.vue'
    18. // 导出模块
    19. export default {
    20. components:{
    21. TopNav,LeftNav
    22. },
    23. data(){
    24. return{
    25. asideClass:'main-aside'
    26. }
    27. },
    28. created() {
    29. this.$root.Bus.$on('aaa',v=>{
    30. this.asideClass = v ? 'main-aside-collapsed' : 'main-aside';
    31. });
    32. }
    33. };
    34. script>
    35. <style scoped>
    36. .main-container {
    37. height: 100%;
    38. width: 100%;
    39. box-sizing: border-box;
    40. }
    41. .main-aside-collapsed {
    42. /* 在CSS中,通过对某一样式声明! important ,可以更改默认的CSS样式优先级规则,使该条样式属性声明具有最高优先级 */
    43. width: 64px !important;
    44. height: 100%;
    45. background-color: #334157;
    46. margin: 0px;
    47. }
    48. .main-aside {
    49. width: 240px !important;
    50. height: 100%;
    51. background-color: #334157;
    52. margin: 0px;
    53. }
    54. .main-header,
    55. .main-center {
    56. padding: 0px;
    57. border-left: 2px solid #333;
    58. }
    59. style>

    LeftNav.vue:

    1. <template>
    2. <el-menu default-active="2" class="el-menu-vertical-demo" background-color="#334157"
    3. text-color="#fff" active-text-color="#ffd04b" :collapse="collapsed">
    4. <div class="logobox">
    5. <img class="logoimg" src="../assets/img/logo.png" alt="">
    6. div>
    7. <el-submenu index="1">
    8. <template slot="title">
    9. <i class="el-icon-location">i>
    10. <span>导航一span>
    11. template>
    12. <el-menu-item-group>
    13. <template slot="title">分组一template>
    14. <el-menu-item index="1-1">选项1el-menu-item>
    15. <el-menu-item index="1-2">选项2el-menu-item>
    16. el-menu-item-group>
    17. <el-menu-item-group title="分组2">
    18. <el-menu-item index="1-3">选项3el-menu-item>
    19. el-menu-item-group>
    20. <el-submenu index="1-4">
    21. <template slot="title">选项4template>
    22. <el-menu-item index="1-4-1">选项1el-menu-item>
    23. el-submenu>
    24. el-submenu>
    25. <el-menu-item index="2">
    26. <i class="el-icon-menu">i>
    27. <span slot="title">导航二span>
    28. el-menu-item>
    29. <el-menu-item index="3" disabled>
    30. <i class="el-icon-document">i>
    31. <span slot="title">导航三span>
    32. el-menu-item>
    33. <el-menu-item index="4">
    34. <i class="el-icon-setting">i>
    35. <span slot="title">导航四span>
    36. el-menu-item>
    37. el-menu>
    38. template>
    39. <script>
    40. export default {
    41. data(){
    42. return{
    43. collapsed:false
    44. }
    45. },
    46. created() {
    47. this.$root.Bus.$on('aaa',v=>{
    48. this.collapsed = v;
    49. });
    50. }
    51. }
    52. script>
    53. <style>
    54. .el-menu-vertical-demo:not(.el-menu--collapse) {
    55. width: 240px;
    56. min-height: 400px;
    57. }
    58. .el-menu-vertical-demo:not(.el-menu--collapse) {
    59. border: none;
    60. text-align: left;
    61. }
    62. .el-menu-item-group__title {
    63. padding: 0px;
    64. }
    65. .el-menu-bg {
    66. background-color: #1f2d3d !important;
    67. }
    68. .el-menu {
    69. border: none;
    70. }
    71. .logobox {
    72. height: 40px;
    73. line-height: 40px;
    74. color: #9d9d9d;
    75. font-size: 20px;
    76. text-align: center;
    77. padding: 20px 0px;
    78. }
    79. .logoimg {
    80. height: 40px;
    81. }
    82. style>

    TopNav.vue:

    1. <template>
    2. <el-menu class="el-menu-demo" mode="horizontal" background-color="#334157" text-color="#fff" active-text-color="#fff">
    3. <el-button class="buttonimg">
    4. <img class="showimg" :src="collapsed?imgshow:imgsq" @click="doToggle()">
    5. el-button>
    6. <el-submenu index="2" class="submenu">
    7. <template slot="title">超级管理员template>
    8. <el-menu-item index="2-1">设置el-menu-item>
    9. <el-menu-item index="2-2">个人中心el-menu-item>
    10. <el-menu-item @click="exit()" index="2-3">退出el-menu-item>
    11. el-submenu>
    12. el-menu>
    13. template>
    14. <script>
    15. export default {
    16. data(){
    17. return{
    18. collapsed:false,
    19. imgshow:require('@/assets/img/show.png'),
    20. imgsq:require('@/assets/img/sq.png')
    21. }
    22. }
    23. ,methods:{
    24. doToggle(){
    25. this.collapsed = ! this.collapsed;
    26. //this.$emit()
    27. // 将是否重叠放入总线
    28. this.$root.Bus.$emit('aaa',this.collapsed);
    29. },
    30. exit(){
    31. this.$router.push('/');
    32. }
    33. }
    34. }
    35. script>
    36. <style scoped>
    37. .el-menu-vertical-demo:not(.el-menu--collapse) {
    38. border: none;
    39. }
    40. .submenu {
    41. float: right;
    42. }
    43. .buttonimg {
    44. height: 60px;
    45. background-color: transparent;
    46. border: none;
    47. }
    48. .showimg {
    49. width: 26px;
    50. height: 26px;
    51. position: absolute;
    52. top: 17px;
    53. left: 17px;
    54. }
    55. .showimg:active {
    56. border: none;
    57. }
    58. style>

    准备相对应的图片以下图片:

    2.3.配置组件与路由关系

    2.3.1. 配置组件

    在router包下加入以下代码,如下:

    1. import AppMain from '@/components/AppMain'
    2. import LeftNav from '@/components/LeftNav'
    3. import TopNav from '@/components/TopNav'

    2.3.2.配置路由关系

    在router包下加入以下代码,如下:

    1. {
    2. path: '/AppMain',
    3. name: 'AppMain',
    4. component: AppMain,
    5. children: [
    6. {
    7. path: '/LeftNav',
    8. name: 'LeftNav',
    9. component: LeftNav
    10. },
    11. {
    12. path: '/TopNav',
    13. name: 'TopNav',
    14. component: TopNav
    15. }
    16. ]
    17. }]

    main.js:

    1. // The Vue build version to load with the `import` command
    2. // (runtime-only or standalone) has been set in webpack.base.conf with an alias.
    3. import Vue from 'vue'
    4. // 开发环境:trur && require('@/mock')
    5. // 生产环境:false && require('@/mock')
    6. //开发环境下才会引入mockjs
    7. process.env.MOCK && require('@/mock')
    8. // 1.导入ElementUI依赖
    9. import ElementUI from 'element-ui'
    10. // 2.导入ElementUI样式,避免后期打包样式不同,要放在import App from './App';之前
    11. import 'element-ui/lib/theme-chalk/index.css'
    12. import App from './App'
    13. import router from './router'
    14. // 3增加ElementUI实例
    15. Vue.use(ElementUI)
    16. Vue.config.productionTip = false
    17. // 在main.js文件中引入vue-axios模块
    18. import axios from '@/api/http'
    19. import VueAxios from 'vue-axios'
    20. // 在main.js文件中引入vue-axios模块
    21. Vue.use(VueAxios,axios)
    22. /* eslint-disable no-new */
    23. new Vue({
    24. el: '#app',
    25. router,
    26. data(){
    27. return{
    28. Bus:new Vue()
    29. }
    30. },
    31. components: { App },
    32. template: '<App/>'
    33. })

    展示效果:

             好啦今天到这了,希望能帮到你!!!

  • 相关阅读:
    最新版SpringBoot整合Mybatis-plus,实现增删改查(CRUD)
    [NOIP2006 提高组] 作业调度方案
    射频与麦克斯韦方程组
    使用Spark探索数据
    二叉树的遍历-树-数据结构和算法(Java)
    关于Conversational QA 的一些调研
    初识上位机(下):C#读写PLC数据块数据
    为什么HashMap头插法会造成死循环?
    基于SSM实现智慧幼儿园信息管理系统
    翻译软件Mate Translate mac中文版介绍说明
  • 原文地址:https://blog.csdn.net/m0_74915426/article/details/133280762