首页导航和总线使用

文章介绍了Mock.js如何帮助前端在后端接口未完成时进行模拟数据开发,包括安装配置、使用方法。同时讲解了Vue中的组件通信,特别是通过Vue中央总线(VueEventBus)实现不同组件间的数据共享和交互。

目录

1.Mock.js

  1.1:什么是mock.js?

  1.2:功能

  1.3:安装配置

  1.4:mock的使用

2.登录注册跳转

 2.1添加一个注册Register.vue在views文件夹中

 3.组件通信

 3.1:什么是总线通信?

 3.2:逻辑图

 3.3:配置


1.Mock.js

  1.1:什么是mock.js?

mock.js 是一款模拟数据生成器,帮助前端人员独立于后端进行开发,帮助编写单元测试, 前后端合作期间,后端人员需给到需开发的接口名称、返回的数据格式,前端人员根据这些数据格式,编写mock,可直接用于开发,编写页面交互。

  1.2:功能

根据数据模板生成模拟数据 拦截真实的ajax请求,并模拟Ajax请求,生成并返回模拟数据 基于HTMML模板生成模拟数据 

  1.3:安装配置

npm i mockjs -D 

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

dev.env.js:

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

 prod.env.js:

 module.exports = {
  NODE_ENV: '"production"',
	MOCK: 'false'
}

我们还需要在main.js中使用

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

这样我们就只会在开发环境中使用mock模拟数据了。

  1.4:mock的使用

 我们需要创建mock目录,在mock文件夹下创建index.js和json文件夹,在json文件夹中创建login-mock.js,用来表示登录的模拟数据。

在index.js中配置如下代码

import Mock from 'mockjs' //引入mockjs,npm已安装
import action from '@/api/action' //引入请求地址

//全局设置:设置所有ajax请求的超时时间,模拟网络传输耗时
Mock.setup({
	// timeout: 400  //延时400ms请求到数据
	timeout: 200 - 400 //延时200-400ms请求到数据
})

//引登陆的测试数据,并添加至mockjs
import loginInfo from '@/mock/json/login-mock.js'
let s1 = action.getFullPath('SYSTEM_USER_DOLOGIN')
Mock.mock(s1, "post", loginInfo)
// Mock.mock(s1, /post|get/i, loginInfo)

 这里的意思是跟url进行绑定。

我们在创建的login-mock.js进行随机数据编写

// const loginInfo = {
// 	code: -1,
// 	message: '密码错误'
// }

//使用mockjs的模板生成随机数据
const loginInfo = {
	'code|-1-0': 0,
	'message|3-10': 'msg'
}
export default loginInfo;

来到login.vue中,找到登录接口的方法doSubmit

这里我们需要对该方法进行修改

doSubmit: function () {
    let params = {
        username: this.username,
        password: this.password
    };
    console.log(params);
    let url = this.axios.urls.SYSTEM_USER_DOLOGIN;
    this.axios.post(url, params).then(response => {
        console.log(response);
        if (response.data.code == 0) {
            this.$message({
                message: response.data.message,
                type: 'success'
            })
        } else {
            this.$message({
                message: response.data.message,
                type: 'error'
            })
        }
    }).catch(error => {
        console.log(error);
    });
}

这样我们就实现了数据模拟。 

2.登录注册跳转

 2.1添加一个注册Register.vue在views文件夹中

<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 label="">
        <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="gotoLogin()">用户登录</el-link>
      </el-row>
    </el-form>
  </div>
</template>

<script>

export default {
  name: 'Login',
  data: function () {
    return {
      username: "admin",
      password: "123"
    }
  },
  methods: {
    doSubmit: function () {

    },
    gotoLogin(){
      this.$router.push({path: '/'})
    }
  }
}
</script>

<style scoped>
.login-wrap {
  box-sizing: border-box;
  width: 100%;
  height: 100%;
  padding-top: 10%;
  /* 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>

 我们通过Login.vue跳转到Register.vue去实现注册功能

gotoRegister(){
    this.$router.push({path: '/register'})
}

 

在登录界面点击注册,让这个按钮出发该方法,跳转到指定路径:localhost:8083/#/register

 3.组件通信

这里我们主要使用总线通信。

3.1:什么是总线通信?

Vue中央总线通信(Vue Event Bus)是一种 Vue.js 的通信机制,它允许不同组件之间相互传递数据,实现了数据的传递与共享。 在Vue 中,每个组件都是独立的,它们拥有自己的状态以及和其他组件的交互。但在某些情况下,我们需要让组件之间互相通信。比如在一个大型的应用中,有多个组件需要共享同一个数据,此时,我们可以使用 Vue 中央总线通信来实现多个组件之间的数据共享。

 3.2:逻辑图

   3.3:配置

main.js:

//在new Vue中添加
data(){
  return{
      Bus: new Vue({})
  }
}

在components中添加内容

AppMain.vue:

<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">Main</el-main>
    </el-container>
  </el-container>
</template>

<script>
// 导入组件
import TopNav from '@/components/TopNav.vue'
import LeftNav from '@/components/LeftNav.vue'

// 导出模块
export default {
	
  components: {LeftNav, TopNav},
  data() {
    return {
      asideClass: 'main-aside'
    }
  },
  created() {
    this.$root.Bus.$on('doCollapsed', v => {
      //v指的是topNav传递过来的this.collapsed
      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;
  transition: width 0.6s ease;
}

.main-aside {
  width: 240px !important;
  height: 100%;
  background-color: #334157;
  margin: 0px;
  transition: width 0.6s ease;
}

.main-header,.main-center {
  padding: 0px;
  border-left: 2px solid #333;
}
</style>

TopNav.vue:

<template>
  <!-- <el-menu :default-active="activeIndex2" class="el-menu-demo" mode="horizontal" @select="handleSelect" background-color="#545c64"
   text-color="#fff" active-text-color="#ffd04b">
    <el-menu-item index="1">处理中心</el-menu-item>
    <el-submenu index="2">
      <template slot="title">我的工作台</template>
      <el-menu-item index="2-1">选项1</el-menu-item>
      <el-menu-item index="2-2">选项2</el-menu-item>
      <el-menu-item index="2-3">选项3</el-menu-item>
      <el-submenu index="2-4">
        <template slot="title">选项4</template>
        <el-menu-item index="2-4-1">选项1</el-menu-item>
        <el-menu-item index="2-4-2">选项2</el-menu-item>
        <el-menu-item index="2-4-3">选项3</el-menu-item>
      </el-submenu>
    </el-submenu>

    <el-menu-item index="3" disabled>消息中心</el-menu-item>
    <el-menu-item index="4"><a href="https://www.ele.me" target="_blank">订单管理</a></el-menu-item>
  </el-menu> -->
  <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('doCollapsed', this.collapsed);
    },
    exit(){
      this.$router.push({path:'/'})
    }
  }
}
</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>

 LeftNav.vue:

<template>
  <el-menu default-active="2" class="el-menu-vertical-demo" background-color="#334157"
           text-color="#fff" active-text-color="#ffd04b" :collapse="collapsed">
    <!-- <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"> -->
    <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">选项1</el-menu-item>
        <el-menu-item index="1-2">选项2</el-menu-item>
      </el-menu-item-group>
      <el-menu-item-group title="分组2">
        <el-menu-item index="1-3">选项3</el-menu-item>
      </el-menu-item-group>
      <el-submenu index="1-4">
        <template slot="title">选项4</template>
        <el-menu-item index="1-4-1">选项1</el-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('doCollapsed', v => {
        //v指的是topNav传递过来的this.collapsed
      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>

配置路由:

{
		path: '/appMain',
		name: 'AppMain',
		component: AppMain,
		children: [{
				path: '/TopNav',
				name: 'TopNav',
				component: TopNav
			},{
				path: '/leftNav',
				name: 'LeftNav',
				component: LeftNav
	        }
		]
	}

 定义方法

//在methods中添加exit()方法
exit(){
	this.$router.push({path:'/login'})
}

这样我们就实现了总线通信功能。 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值