• 关于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(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiIHN0YW5kYWxvbmU9Im5vIj8+Cjxzdmcgd2lkdGg9IjEzNjFweCIgaGVpZ2h0PSI2MDlweCIgdmlld0JveD0iMCAwIDEzNjEgNjA5IiB2ZXJzaW9uPSIxLjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiPgogICAgPCEtLSBHZW5lcmF0b3I6IFNrZXRjaCA0Ni4yICg0NDQ5NikgLSBodHRwOi8vd3d3LmJvaGVtaWFuY29kaW5nLmNvbS9za2V0Y2ggLS0+CiAgICA8dGl0bGU+R3JvdXAgMjE8L3RpdGxlPgogICAgPGRlc2M+Q3JlYXRlZCB3aXRoIFNrZXRjaC48L2Rlc2M+CiAgICA8ZGVmcz48L2RlZnM+CiAgICA8ZyBpZD0iQW50LURlc2lnbi1Qcm8tMy4wIiBzdHJva2U9Im5vbmUiIHN0cm9rZS13aWR0aD0iMSIgZmlsbD0ibm9uZSIgZmlsbC1ydWxlPSJldmVub2RkIj4KICAgICAgICA8ZyBpZD0i6LSm5oi35a+G56CB55m75b2VLeagoemqjCIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoLTc5LjAwMDAwMCwgLTgyLjAwMDAwMCkiPgogICAgICAgICAgICA8ZyBpZD0iR3JvdXAtMjEiIHRyYW5zZm9ybT0idHJhbnNsYXRlKDc3LjAwMDAwMCwgNzMuMDAwMDAwKSI+CiAgICAgICAgICAgICAgICA8ZyBpZD0iR3JvdXAtMTgiIG9wYWNpdHk9IjAuOCIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoNzQuOTAxNDE2LCA1NjkuNjk5MTU4KSByb3RhdGUoLTcuMDAwMDAwKSB0cmFuc2xhdGUoLTc0LjkwMTQxNiwgLTU2OS42OTkxNTgpIHRyYW5zbGF0ZSg0LjkwMTQxNiwgNTI1LjE5OTE1OCkiPgogICAgICAgICAgICAgICAgICAgIDxlbGxpcHNlIGlkPSJPdmFsLTExIiBmaWxsPSIjQ0ZEQUU2IiBvcGFjaXR5PSIwLjI1IiBjeD0iNjMuNTc0ODc5MiIgY3k9IjMyLjQ2ODM2NyIgcng9IjIxLjc4MzA0NzkiIHJ5PSIyMS43NjYwMDgiPjwvZWxsaXBzZT4KICAgICAgICAgICAgICAgICAgICA8ZWxsaXBzZSBpZD0iT3ZhbC0zIiBmaWxsPSIjQ0ZEQUU2IiBvcGFjaXR5PSIwLjU5OTk5OTk2NCIgY3g9IjUuOTg3NDY0NzkiIGN5PSIxMy44NjY4NjAxIiByeD0iNS4yMTczOTEzIiByeT0iNS4yMTMzMDk5NyI+PC9lbGxpcHNlPgogICAgICAgICAgICAgICAgICAgIDxwYXRoIGQ9Ik0zOC4xMzU0NTE0LDg4LjM1MjAyMTUgQzQzLjg5ODQyMjcsODguMzUyMDIxNSA0OC41NzAyMzQsODMuNjgzODY0NyA0OC41NzAyMzQsNzcuOTI1NDAxNSBDNDguNTcwMjM0LDcyLjE2NjkzODMgNDMuODk4NDIyNyw2Ny40OTg3ODE2IDM4LjEzNTQ1MTQsNjcuNDk4NzgxNiBDMzIuMzcyNDgwMSw2Ny40OTg3ODE2IDI3LjcwMDY2ODgsNzIuMTY2OTM4MyAyNy43MDA2Njg4LDc3LjkyNTQwMTUgQzI3LjcwMDY2ODgsODMuNjgzODY0NyAzMi4zNzI0ODAxLDg4LjM1MjAyMTUgMzguMTM1NDUxNCw4OC4zNTIwMjE1IFoiIGlkPSJPdmFsLTMtQ29weSIgZmlsbD0iI0NGREFFNiIgb3BhY2l0eT0iMC40NSI+PC9wYXRoPgogICAgICAgICAgICAgICAgICAgIDxwYXRoIGQ9Ik02NC4yNzc1NTgyLDMzLjE3MDQ5NjMgTDExOS4xODU4MzYsMTYuNTY1NDkxNSIgaWQ9IlBhdGgtMTIiIHN0cm9rZT0iI0NGREFFNiIgc3Ryb2tlLXdpZHRoPSIxLjczOTEzMDQzIiBzdHJva2UtbGluZWNhcD0icm91bmQiIHN0cm9rZS1saW5lam9pbj0icm91bmQiPjwvcGF0aD4KICAgICAgICAgICAgICAgICAgICA8cGF0aCBkPSJNNDIuMTQzMTcwOCwyNi41MDAyNjgxIEw3LjcxMTkwMTYyLDE0LjU2NDA3MDIiIGlkPSJQYXRoLTE2IiBzdHJva2U9IiNFMEI0QjciIHN0cm9rZS13aWR0aD0iMC43MDI2Nzg5NjQiIG9wYWNpdHk9IjAuNyIgc3Ryb2tlLWxpbmVjYXA9InJvdW5kIiBzdHJva2UtbGluZWpvaW49InJvdW5kIiBzdHJva2UtZGFzaGFycmF5PSIxLjQwNTM1Nzg5OTg3MzE1MywyLjEwODAzNjk1MzQ2OTk4MSI+PC9wYXRoPgogICAgICAgICAgICAgICAgICAgIDxwYXRoIGQ9Ik02My45MjYyMTg3LDMzLjUyMTU2MSBMNDMuNjcyMTMyNiw2OS4zMjUwOTUxIiBpZD0iUGF0aC0xNSIgc3Ryb2tlPSIjQkFDQUQ5IiBzdHJva2Utd2lkdGg9IjAuNzAyNjc4OTY0IiBzdHJva2UtbGluZWNhcD0icm91bmQiIHN0cm9rZS1saW5lam9pbj0icm91bmQiIHN0cm9rZS1kYXNoYXJyYXk9IjEuNDA1MzU3ODk5ODczMTUzLDIuMTA4MDM2OTUzNDY5OTgxIj48L3BhdGg+CiAgICAgICAgICAgICAgICAgICAgPGcgaWQ9Ikdyb3VwLTE3IiB0cmFuc2Zvcm09InRyYW5zbGF0ZSgxMjYuODUwOTIyLCAxMy41NDM2NTQpIHJvdGF0ZSgzMC4wMDAwMDApIHRyYW5zbGF0ZSgtMTI2Ljg1MDkyMiwgLTEzLjU0MzY1NCkgdHJhbnNsYXRlKDExNy4yODU3MDUsIDQuMzgxODg5KSIgZmlsbD0iI0NGREFFNiI+CiAgICAgICAgICAgICAgICAgICAgICAgIDxlbGxpcHNlIGlkPSJPdmFsLTQiIG9wYWNpdHk9IjAuNDUiIGN4PSI5LjEzNDgyNjUzIiBjeT0iOS4xMjc2ODA3NiIgcng9IjkuMTM0ODI2NTMiIHJ5PSI5LjEyNzY4MDc2Ij48L2VsbGlwc2U+CiAgICAgICAgICAgICAgICAgICAgICAgIDxwYXRoIGQ9Ik0xOC4yNjk2NTMxLDE4LjI1NTM2MTUgQzE4LjI2OTY1MzEsMTMuMjE0MjgyNiAxNC4xNzk4NTE5LDkuMTI3NjgwNzYgOS4xMzQ4MjY1Myw5LjEyNzY4MDc2IEM0LjA4OTgwMTE0LDkuMTI3NjgwNzYgMCwxMy4yMTQyODI2IDAsMTguMjU1MzYxNSBMMTguMjY5NjUzMSwxOC4yNTUzNjE1IFoiIGlkPSJPdmFsLTQiIHRyYW5zZm9ybT0idHJhbnNsYXRlKDkuMTM0ODI3LCAxMy42OTE1MjEpIHNjYWxlKC0xLCAtMSkgdHJhbnNsYXRlKC05LjEzNDgyNywgLTEzLjY5MTUyMSkgIj48L3BhdGg+CiAgICAgICAgICAgICAgICAgICAgPC9nPgogICAgICAgICAgICAgICAgPC9nPgogICAgICAgICAgICAgICAgPGcgaWQ9Ikdyb3VwLTE0IiB0cmFuc2Zvcm09InRyYW5zbGF0ZSgyMTYuMjk0NzAwLCAxMjMuNzI1NjAwKSByb3RhdGUoLTUuMDAwMDAwKSB0cmFuc2xhdGUoLTIxNi4yOTQ3MDAsIC0xMjMuNzI1NjAwKSB0cmFuc2xhdGUoMTA2LjI5NDcwMCwgMzUuMjI1NjAwKSI+CiAgICAgICAgICAgICAgICAgICAgPGVsbGlwc2UgaWQ9Ik92YWwtMiIgZmlsbD0iI0NGREFFNiIgb3BhY2l0eT0iMC4yNSIgY3g9IjI5LjExNzY0NzEiIGN5PSIyOS4xNDAyNDM5IiByeD0iMjkuMTE3NjQ3MSIgcnk9IjI5LjE0MDI0MzkiPjwvZWxsaXBzZT4KICAgICAgICAgICAgICAgICAgICA8ZWxsaXBzZSBpZD0iT3ZhbC0yIiBmaWxsPSIjQ0ZEQUU2IiBvcGFjaXR5PSIwLjMiIGN4PSIyOS4xMTc2NDcxIiBjeT0iMjkuMTQwMjQzOSIgcng9IjIxLjU2ODYyNzUiIHJ5PSIyMS41ODUzNjU5Ij48L2VsbGlwc2U+CiAgICAgICAgICAgICAgICAgICAgPGVsbGlwc2UgaWQ9Ik92YWwtMi1Db3B5IiBzdHJva2U9IiNDRkRBRTYiIG9wYWNpdHk9IjAuNCIgY3g9IjE3OS4wMTk2MDgiIGN5PSIxMzguMTQ2MzQxIiByeD0iMjMuNzI1NDkwMiIgcnk9IjIzLjc0MzkwMjQiPjwvZWxsaXBzZT4KICAgICAgICAgICAgICAgICAgICA8ZWxsaXBzZSBpZD0iT3ZhbC0yIiBmaWxsPSIjQkFDQUQ5IiBvcGFjaXR5PSIwLjUiIGN4PSIyOS4xMTc2NDcxIiBjeT0iMjkuMTQwMjQzOSIgcng9IjEwLjc4NDMxMzciIHJ5PSIxMC43OTI2ODI5Ij48L2VsbGlwc2U+CiAgICAgICAgICAgICAgICAgICAgPHBhdGggZD0iTTI5LjExNzY0NzEsMzkuOTMyOTI2OCBMMjkuMTE3NjQ3MSwxOC4zNDc1NjEgQzIzLjE2MTYzNTEsMTguMzQ3NTYxIDE4LjMzMzMzMzMsMjMuMTc5NjA5NyAxOC4zMzMzMzMzLDI5LjE0MDI0MzkgQzE4LjMzMzMzMzMsMzUuMTAwODc4MSAyMy4xNjE2MzUxLDM5LjkzMjkyNjggMjkuMTE3NjQ3MSwzOS45MzI5MjY4IFoiIGlkPSJPdmFsLTIiIGZpbGw9IiNCQUNBRDkiPjwvcGF0aD4KICAgICAgICAgICAgICAgICAgICA8ZyBpZD0iR3JvdXAtOSIgb3BhY2l0eT0iMC40NSIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoMTcyLjAwMDAwMCwgMTMxLjAwMDAwMCkiIGZpbGw9IiNFNkExQTYiPgogICAgICAgICAgICAgICAgICAgICAgICA8ZWxsaXBzZSBpZD0iT3ZhbC0yLUNvcHktMiIgY3g9IjcuMDE5NjA3ODQiIGN5PSI3LjE0NjM0MTQ2IiByeD0iNi40NzA1ODgyNCIgcnk9IjYuNDc1NjA5NzYiPjwvZWxsaXBzZT4KICAgICAgICAgICAgICAgICAgICAgICAgPHBhdGggZD0iTTAuNTQ5MDE5NjA4LDEzLjYyMTk1MTIgQzQuMTIyNjI2ODEsMTMuNjIxOTUxMiA3LjAxOTYwNzg0LDEwLjcyMjcyMiA3LjAxOTYwNzg0LDcuMTQ2MzQxNDYgQzcuMDE5NjA3ODQsMy41Njk5NjA5NSA0LjEyMjYyNjgxLDAuNjcwNzMxNzA3IDAuNTQ5MDE5NjA4LDAuNjcwNzMxNzA3IEwwLjU0OTAxOTYwOCwxMy42MjE5NTEyIFoiIGlkPSJPdmFsLTItQ29weS0yIiB0cmFuc2Zvcm09InRyYW5zbGF0ZSgzLjc4NDMxNCwgNy4xNDYzNDEpIHNjYWxlKC0xLCAxKSB0cmFuc2xhdGUoLTMuNzg0MzE0LCAtNy4xNDYzNDEpICI+PC9wYXRoPgogICAgICAgICAgICAgICAgICAgIDwvZz4KICAgICAgICAgICAgICAgICAgICA8ZWxsaXBzZSBpZD0iT3ZhbC0xMCIgZmlsbD0iI0NGREFFNiIgY3g9IjIxOC4zODIzNTMiIGN5PSIxMzguNjg1OTc2IiByeD0iMS42MTc2NDcwNiIgcnk9IjEuNjE4OTAyNDQiPjwvZWxsaXBzZT4KICAgICAgICAgICAgICAgICAgICA8ZWxsaXBzZSBpZD0iT3ZhbC0xMC1Db3B5LTIiIGZpbGw9IiNFMEI0QjciIG9wYWNpdHk9IjAuMzUiIGN4PSIxNzkuNTU4ODI0IiBjeT0iMTc1LjM4MTA5OCIgcng9IjEuNjE3NjQ3MDYiIHJ5PSIxLjYxODkwMjQ0Ij48L2VsbGlwc2U+CiAgICAgICAgICAgICAgICAgICAgPGVsbGlwc2UgaWQ9Ik92YWwtMTAtQ29weSIgZmlsbD0iI0UwQjRCNyIgb3BhY2l0eT0iMC4zNSIgY3g9IjE4MC4wOTgwMzkiIGN5PSIxMDIuNTMwNDg4IiByeD0iMi4xNTY4NjI3NSIgcnk9IjIuMTU4NTM2NTkiPjwvZWxsaXBzZT4KICAgICAgICAgICAgICAgICAgICA8cGF0aCBkPSJNMjguOTk4NTM4MSwyOS45NjcxNTk4IEwxNzEuMTUxMDE4LDEzMi44NzYwMjQiIGlkPSJQYXRoLTExIiBzdHJva2U9IiNDRkRBRTYiIG9wYWNpdHk9IjAuOCI+PC9wYXRoPgogICAgICAgICAgICAgICAgPC9nPgogICAgICAgICAgICAgICAgPGcgaWQ9Ikdyb3VwLTEwIiBvcGFjaXR5PSIwLjc5OTk5OTk1MiIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoMTA1NC4xMDA2MzUsIDM2LjY1OTMxNykgcm90YXRlKC0xMS4wMDAwMDApIHRyYW5zbGF0ZSgtMTA1NC4xMDA2MzUsIC0zNi42NTkzMTcpIHRyYW5zbGF0ZSgxMDI2LjYwMDYzNSwgNC42NTkzMTcpIj4KICAgICAgICAgICAgICAgICAgICA8ZWxsaXBzZSBpZD0iT3ZhbC03IiBzdHJva2U9IiNDRkRBRTYiIHN0cm9rZS13aWR0aD0iMC45NDExNzY0NzEiIGN4PSI0My44MTM1NTkzIiBjeT0iMzIiIHJ4PSIxMS4xODY0NDA3IiByeT0iMTEuMjk0MTE3NiI+PC9lbGxpcHNlPgogICAgICAgICAgICAgICAgICAgIDxnIGlkPSJHcm91cC0xMiIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoMzQuNTk2Nzc0LCAyMy4xMTExMTEpIiBmaWxsPSIjQkFDQUQ5Ij4KICAgICAgICAgICAgICAgICAgICAgICAgPGVsbGlwc2UgaWQ9Ik92YWwtNyIgb3BhY2l0eT0iMC40NSIgY3g9IjkuMTg1MzQ3MTgiIGN5PSI4Ljg4ODg4ODg5IiByeD0iOC40NzQ1NzYyNyIgcnk9IjguNTU2MTQ5NzMiPjwvZWxsaXBzZT4KICAgICAgICAgICAgICAgICAgICAgICAgPHBhdGggZD0iTTkuMTg1MzQ3MTgsMTcuNDQ1MDM4NiBDMTMuODY1NzI2NCwxNy40NDUwMzg2IDE3LjY1OTkyMzUsMTMuNjE0MzE5OSAxNy42NTk5MjM1LDguODg4ODg4ODkgQzE3LjY1OTkyMzUsNC4xNjM0NTc4NyAxMy44NjU3MjY0LDAuMzMyNzM5MTU2IDkuMTg1MzQ3MTgsMC4zMzI3MzkxNTYgTDkuMTg1MzQ3MTgsMTcuNDQ1MDM4NiBaIiBpZD0iT3ZhbC03Ij48L3BhdGg+CiAgICAgICAgICAgICAgICAgICAgPC9nPgogICAgICAgICAgICAgICAgICAgIDxwYXRoIGQ9Ik0zNC42NTk3Mzg1LDI0LjgwOTY5NCBMNS43MTY2NjA4NCw0Ljc2ODc4OTQ1IiBpZD0iUGF0aC0yIiBzdHJva2U9IiNDRkRBRTYiIHN0cm9rZS13aWR0aD0iMC45NDExNzY0NzEiPjwvcGF0aD4KICAgICAgICAgICAgICAgICAgICA8ZWxsaXBzZSBpZD0iT3ZhbCIgc3Ryb2tlPSIjQ0ZEQUU2IiBzdHJva2Utd2lkdGg9IjAuOTQxMTc2NDcxIiBjeD0iMy4yNjI3MTE4NiIgY3k9IjMuMjk0MTE3NjUiIHJ4PSIzLjI2MjcxMTg2IiByeT0iMy4yOTQxMTc2NSI+PC9lbGxpcHNlPgogICAgICAgICAgICAgICAgICAgIDxlbGxpcHNlIGlkPSJPdmFsLUNvcHkiIGZpbGw9IiNGN0UxQUQiIGN4PSIyLjc5NjYxMDE3IiBjeT0iNjEuMTc2NDcwNiIgcng9IjIuNzk2NjEwMTciIHJ5PSIyLjgyMzUyOTQxIj48L2VsbGlwc2U+CiAgICAgICAgICAgICAgICAgICAgPHBhdGggZD0iTTM0LjYzMTI0NDMsMzkuMjkyMjcxMiBMNS4wNjM2NjY2Myw1OS43ODUwODIiIGlkPSJQYXRoLTEwIiBzdHJva2U9IiNDRkRBRTYiIHN0cm9rZS13aWR0aD0iMC45NDExNzY0NzEiPjwvcGF0aD4KICAgICAgICAgICAgICAgIDwvZz4KICAgICAgICAgICAgICAgIDxnIGlkPSJHcm91cC0xOSIgb3BhY2l0eT0iMC4zMyIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoMTI4Mi41MzcyMTksIDQ0Ni41MDI4NjcpIHJvdGF0ZSgtMTAuMDAwMDAwKSB0cmFuc2xhdGUoLTEyODIuNTM3MjE5LCAtNDQ2LjUwMjg2NykgdHJhbnNsYXRlKDExNDIuNTM3MjE5LCAzMjcuNTAyODY3KSI+CiAgICAgICAgICAgICAgICAgICAgPGcgaWQ9Ikdyb3VwLTE3IiB0cmFuc2Zvcm09InRyYW5zbGF0ZSgxNDEuMzMzNTM5LCAxMDQuNTAyNzQyKSByb3RhdGUoMjc1LjAwMDAwMCkgdHJhbnNsYXRlKC0xNDEuMzMzNTM5LCAtMTA0LjUwMjc0MikgdHJhbnNsYXRlKDEyOS4zMzM1MzksIDkyLjUwMjc0MikiIGZpbGw9IiNCQUNBRDkiPgogICAgICAgICAgICAgICAgICAgICAgICA8Y2lyY2xlIGlkPSJPdmFsLTQiIG9wYWNpdHk9IjAuNDUiIGN4PSIxMS42NjY2NjY3IiBjeT0iMTEuNjY2NjY2NyIgcj0iMTEuNjY2NjY2NyI+PC9jaXJjbGU+CiAgICAgICAgICAgICAgICAgICAgICAgIDxwYXRoIGQ9Ik0yMy4zMzMzMzMzLDIzLjMzMzMzMzMgQzIzLjMzMzMzMzMsMTYuODkwMDExMyAxOC4xMDk5ODg3LDExLjY2NjY2NjcgMTEuNjY2NjY2NywxMS42NjY2NjY3IEM1LjIyMzM0NDU5LDExLjY2NjY2NjcgMCwxNi44OTAwMTEzIDAsMjMuMzMzMzMzMyBMMjMuMzMzMzMzMywyMy4zMzMzMzMzIFoiIGlkPSJPdmFsLTQiIHRyYW5zZm9ybT0idHJhbnNsYXRlKDExLjY2NjY2NywgMTcuNTAwMDAwKSBzY2FsZSgtMSwgLTEpIHRyYW5zbGF0ZSgtMTEuNjY2NjY3LCAtMTcuNTAwMDAwKSAiPjwvcGF0aD4KICAgICAgICAgICAgICAgICAgICA8L2c+CiAgICAgICAgICAgICAgICAgICAgPGNpcmNsZSBpZD0iT3ZhbC01LUNvcHktNiIgZmlsbD0iI0NGREFFNiIgY3g9IjIwMS44MzMzMzMiIGN5PSI4Ny41IiByPSI1LjgzMzMzMzMzIj48L2NpcmNsZT4KICAgICAgICAgICAgICAgICAgICA8cGF0aCBkPSJNMTQzLjUsODguODEyNjY4NSBMMTU1LjA3MDUwMSwxNy42MDM4NTQ0IiBpZD0iUGF0aC0xNyIgc3Ryb2tlPSIjQkFDQUQ5IiBzdHJva2Utd2lkdGg9IjEuMTY2NjY2NjciPjwvcGF0aD4KICAgICAgICAgICAgICAgICAgICA8cGF0aCBkPSJNMTcuNSwzNy4zMzMzMzMzIEwxMjcuNDY2MjUyLDk3LjY0NDk3MzUiIGlkPSJQYXRoLTE4IiBzdHJva2U9IiNCQUNBRDkiIHN0cm9rZS13aWR0aD0iMS4xNjY2NjY2NyI+PC9wYXRoPgogICAgICAgICAgICAgICAgICAgIDxwb2x5bGluZSBpZD0iUGF0aC0xOSIgc3Ryb2tlPSIjQ0ZEQUU2IiBzdHJva2Utd2lkdGg9IjEuMTY2NjY2NjciIHBvaW50cz0iMTQzLjkwMjU5NyAxMjAuMzAyMjgxIDE3NC45MzU0NTUgMjMxLjU3MTM0MiAzOC41IDE0Ny41MTA4NDcgMTI2LjM2Njk0MSAxMTAuODMzMzMzIj48L3BvbHlsaW5lPgogICAgICAgICAgICAgICAgICAgIDxwYXRoIGQ9Ik0xNTkuODMzMzMzLDk5Ljc0NTM4NDIgTDE5NS40MTY2NjcsODkuMjUiIGlkPSJQYXRoLTIwIiBzdHJva2U9IiNFMEI0QjciIHN0cm9rZS13aWR0aD0iMS4xNjY2NjY2NyIgb3BhY2l0eT0iMC42Ij48L3BhdGg+CiAgICAgICAgICAgICAgICAgICAgPHBhdGggZD0iTTIwNS4zMzMzMzMsODIuMTM3MjEwNSBMMjM4LjcxOTQwNiwzNi4xNjY2NjY3IiBpZD0iUGF0aC0yNCIgc3Ryb2tlPSIjQkFDQUQ5IiBzdHJva2Utd2lkdGg9IjEuMTY2NjY2NjciPjwvcGF0aD4KICAgICAgICAgICAgICAgICAgICA8cGF0aCBkPSJNMjY2LjcyMzQyNCwxMzIuMjMxOTg4IEwyMDcuMDgzMzMzLDkwLjQxNjY2NjciIGlkPSJQYXRoLTI1IiBzdHJva2U9IiNDRkRBRTYiIHN0cm9rZS13aWR0aD0iMS4xNjY2NjY2NyI+PC9wYXRoPgogICAgICAgICAgICAgICAgICAgIDxjaXJjbGUgaWQ9Ik92YWwtNSIgZmlsbD0iI0MxRDFFMCIgY3g9IjE1Ni45MTY2NjciIGN5PSI4Ljc1IiByPSI4Ljc1Ij48L2NpcmNsZT4KICAgICAgICAgICAgICAgICAgICA8Y2lyY2xlIGlkPSJPdmFsLTUtQ29weS0zIiBmaWxsPSIjQzFEMUUwIiBjeD0iMzkuMDgzMzMzMyIgY3k9IjE0OC43NSIgcj0iNS4yNSI+PC9jaXJjbGU+CiAgICAgICAgICAgICAgICAgICAgPGNpcmNsZSBpZD0iT3ZhbC01LUNvcHktMiIgZmlsbC1vcGFjaXR5PSIwLjYiIGZpbGw9IiNEMURFRUQiIGN4PSI4Ljc1IiBjeT0iMzMuMjUiIHI9IjguNzUiPjwvY2lyY2xlPgogICAgICAgICAgICAgICAgICAgIDxjaXJjbGUgaWQ9Ik92YWwtNS1Db3B5LTQiIGZpbGwtb3BhY2l0eT0iMC42IiBmaWxsPSIjRDFERUVEIiBjeD0iMjQzLjgzMzMzMyIgY3k9IjMwLjMzMzMzMzMiIHI9IjUuODMzMzMzMzMiPjwvY2lyY2xlPgogICAgICAgICAgICAgICAgICAgIDxjaXJjbGUgaWQ9Ik92YWwtNS1Db3B5LTUiIGZpbGw9IiNFMEI0QjciIGN4PSIxNzUuNTgzMzMzIiBjeT0iMjMyLjc1IiByPSI1LjI1Ij48L2NpcmNsZT4KICAgICAgICAgICAgICAgIDwvZz4KICAgICAgICAgICAgPC9nPgogICAgICAgIDwvZz4KICAgIDwvZz4KPC9zdmc+);
    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