当前位置:   article > 正文

【Vue.js】使用Element搭建首页导航&左侧菜单_vue管理项目中,左侧栏如何添加

vue管理项目中,左侧栏如何添加

目录

Mock.js

是什么

有什么好处

安装mockjs

​编辑 

引入mockjs

 mockjs使用

 login-mock

Bus事物总线 

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

结合总线完成组件通讯


Mock.js

是什么

Mock.js是一个用于生成随机数据的模拟数据生成器。它可以帮助开发人员模拟接口请求,生成随机的数据,以便进行开发和测试。Mock.js提供了丰富的数据模板和随机数据生成规则,可以根据需求生成各种类型的数据,如字符串、数字、布尔值、数组、对象等。同时,Mock.js还支持拦截Ajax请求,使得在开发过程中可以独立于后端接口进行前端开发和测试。

有什么好处

使用Mock.js可以有效地提高开发效率,尤其在前后端分离的开发模式下,可以让前端开发人员独立于后端接口进行开发,减少对后端接口的依赖性。此外,Mock.js还可以模拟接口请求的各种场景,如请求失败、请求超时等,以便测试前端页面的容错性和稳定性。 

安装mockjs

npm i mockjs -D

注意:SPA项目工作区间使用cmd执行该命令

执行完毕之后,在devDependencies下会发现已下载好mockjs插件,证明已经安装好了

 

引入mockjs

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

dev.env.js

加入Mock:'true'

  1. module.exports = merge(prodEnv, {
  2. NODE_ENV: '"development"',
  3. MOCK: 'true'
  4. })

prod.env.js(生产坏境):

加入Mock:'flase'

  1. module.exports = {
  2. NODE_ENV: '"production"',
  3. MOCK: 'false'
  4. }

 mian.js导入Mock动态依赖

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

 mockjs使用

导入两个js

 login-mock

  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;

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)

登入Login.vue

  1. <template>
  2. <div class="login-wrap">
  3. <el-form class="login-container">
  4. <h1 class="title">用户登录</h1>
  5. <el-form-item label="">
  6. <el-input type="text" v-model="username" placeholder="登录账号" autocomplete="off"></el-input>
  7. </el-form-item>
  8. <el-form-item label="">
  9. <el-input type="password" v-model="password" placeholder="登录密码" autocomplete="off"></el-input>
  10. </el-form-item>
  11. <el-form-item>
  12. <el-button type="primary" style="width:100%;" @click="doSubmit()">提交</el-button>
  13. </el-form-item>
  14. <el-row style="text-align: center;margin-top:-10px">
  15. <el-link type="primary">忘记密码</el-link>
  16. <el-link type="primary" @click="gotoRegister()">用户注册</el-link>
  17. </el-row>
  18. </el-form>
  19. </div>
  20. </template>
  21. <script>
  22. import axios from 'axios'
  23. import qs from 'qs' //用于post请求
  24. export default {
  25. name: 'Login',
  26. data() {
  27. return {
  28. username: "",
  29. password: "",
  30. msg: '啊'
  31. }
  32. },
  33. methods: {
  34. Register() {
  35. this.$router.push('/Register');
  36. },
  37. doSubmit() {
  38. let params = {
  39. username: this.username,
  40. password: this.password
  41. };
  42. console.log(params);
  43. //定义后端都请求地址
  44. var url = this.axios.urls.SYSTEM_USER_DOLOGIN;
  45. //以下是post请求及整合资源
  46. //通过qs中的stringify方法进行格式转换
  47. //注意数据是保存到json对象的params属性
  48. this.axios.post(url,params).then(r => {
  49. console.log(r);
  50. this.$message({
  51. message:r.data.message,
  52. type:r.data.code==0?'success':'error'
  53. });
  54. }).catch(e => {
  55. console.log(e);
  56. });
  57. }
  58. }
  59. }
  60. </script>
  61. <style scoped>
  62. .login-wrap {
  63. box-sizing: border-box;
  64. width: 100%;
  65. height: 100%;
  66. padding-top: 10%;
  67. background-image: url();
  68. /* background-color: #112346; */
  69. background-repeat: no-repeat;
  70. background-position: center right;
  71. background-size: 100%;
  72. }
  73. .login-container {
  74. border-radius: 10px;
  75. margin: 0px auto;
  76. width: 350px;
  77. padding: 30px 35px 15px 35px;
  78. background: #fff;
  79. border: 1px solid #eaeaea;
  80. text-align: left;
  81. box-shadow: 0 0 20px 2px rgba(0, 0, 0, 0.1);
  82. }
  83. .title {
  84. margin: 0px auto 40px auto;
  85. text-align: center;
  86. color: #505458;
  87. }
  88. </style>

效果图 

Bus事物总线 

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

组件(3个)

1.AppMain.vue:布局容器组件

2.LeftAside.vue:左侧菜单组件

3.TopNav.vue:首页导航组件

 APPMian.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">Main</el-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. };
  21. </script>
  22. <style scoped>
  23. .main-container {
  24. height: 100%;
  25. width: 100%;
  26. box-sizing: border-box;
  27. }
  28. .main-aside-collapsed {
  29. /* 在CSS中,通过对某一样式声明! important ,可以更改默认的CSS样式优先级规则,使该条样式属性声明具有最高优先级 */
  30. width: 64px !important;
  31. height: 100%;
  32. background-color: #334157;
  33. margin: 0px;
  34. }
  35. .main-aside {
  36. width: 240px !important;
  37. height: 100%;
  38. background-color: #334157;
  39. margin: 0px;
  40. }
  41. .main-header,
  42. .main-center {
  43. padding: 0px;
  44. border-left: 2px solid #333;
  45. }
  46. </style>

LeftNav.vue

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

TopNav.vue

  1. <template>
  2. <!-- <el-menu :default-active="activeIndex2" class="el-menu-demo" mode="horizontal" @select="handleSelect" background-color="#545c64"
  3. text-color="#fff" active-text-color="#ffd04b">
  4. <el-menu-item index="1">处理中心</el-menu-item>
  5. <el-submenu index="2">
  6. <template slot="title">我的工作台</template>
  7. <el-menu-item index="2-1">选项1</el-menu-item>
  8. <el-menu-item index="2-2">选项2</el-menu-item>
  9. <el-menu-item index="2-3">选项3</el-menu-item>
  10. <el-submenu index="2-4">
  11. <template slot="title">选项4</template>
  12. <el-menu-item index="2-4-1">选项1</el-menu-item>
  13. <el-menu-item index="2-4-2">选项2</el-menu-item>
  14. <el-menu-item index="2-4-3">选项3</el-menu-item>
  15. </el-submenu>
  16. </el-submenu>
  17. <el-menu-item index="3" disabled>消息中心</el-menu-item>
  18. <el-menu-item index="4"><a href="https://www.ele.me" target="_blank">订单管理</a></el-menu-item>
  19. </el-menu> -->
  20. <el-menu class="el-menu-demo" mode="horizontal" background-color="#334157" text-color="#fff" active-text-color="#fff">
  21. <el-button class="buttonimg">
  22. <img class="showimg" :src="collapsed?imgshow:imgsq" @click="doToggle()">
  23. </el-button>
  24. <el-submenu index="2" class="submenu">
  25. <template slot="title">超级管理员</template>
  26. <el-menu-item index="2-1">设置</el-menu-item>
  27. <el-menu-item index="2-2">个人中心</el-menu-item>
  28. <el-menu-item @click="exit()" index="2-3">退出</el-menu-item>
  29. </el-submenu>
  30. </el-menu>
  31. </template>
  32. <script>
  33. export default {
  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>

 

给组件配置路由关系

index.js

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

Login.vue跳转到AppMain(登入跳到主界面)

this.$router.push('/AppMian');

效果图

 

结合总线完成组件通讯

 Bus事件适用于父子组件、非父子组件等之间的通信

定义Bus :main.js

  1. new Vue({
  2. el: '#app',
  3. data(){
  4. return{
  5. Bus:new Vue()
  6. }
  7. },
  8. router,
  9. components: { App },
  10. template: '<App/>'
  11. })

 TopNav.vue

  1. methods:{
  2. doToggle(){//收起左侧菜单事件
  3. this.collapsed=!this.collapsed;
  4. //将是否折叠的变量放入总线
  5. this.$root.Bus.$emit('aaa',this.collapsed);
  6. },
  7. exit(){//退出事件
  8. this.$router.push("/")
  9. }
  10. }

LeftNav.vue

  1. created(){
  2. this.$root.Bus.$on('aaa',r=>{
  3. this.collapsed=r;
  4. });
  5. }

AppMain.vue

  1. created(){
  2. this.$root.Bus.$on('aaa',r=>{
  3. this.asideClass=r ? 'main-aside-collapsed':'main-aside';
  4. });
  5. }

效果图

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/blog/article/detail/73647
推荐阅读
相关标签
  

闽ICP备14008679号