分享web开发知识

注册/登录|最近发布|今日推荐

主页 IT知识网页技术软件开发前端开发代码编程运营维护技术分享教程案例
当前位置:首页 > 软件开发

在vue-lic脚手架中安装mockjs,实现前后端分离开发

发布时间:2023-09-06 02:30责任编辑:赖小花关键词:js后端

在项目开发前期,前端开发中,页面布局基本开发完毕,但是后台还接口还没有开发完,等待后台开发完接口,在进行接口联调,浪费了等待时间,也压缩的测试的时间。所以实现请求拦截,前端模拟后台请求数据就是一个很不错的处理方式。

mockjs

mockjs可以生成随机数据,拦截 Ajax 请求,让前端攻城师独立于后端进行开发。并且支持生成随机的文本、数字、布尔值、日期、邮箱、链接、图片、颜色等。

使用方法

mockjs 可以很方便的添加到以webpack为管理的项目中,以vue-cli脚手架生成的项目为例。vue-cli的搭建不过多赘述,直接进入安装插件过程。

用axios进行请求数据 所以安装axios 和 mockjs 两个包

npm install axios --save npm install mockjs --save-dev

在src中创建一个mock文件夹 并创建一个mock.js文件

// mock.js// 引入mockjsconst Mock = require(‘mockjs‘);// 创建模拟数据let testData = { ???testData: ‘测试mock‘}// Mock.mock( url, post/get , 返回的数据);Mock.mock( ‘/getMockData‘, ‘get‘ , testData)

在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‘import App from ‘./App‘import router from ‘./router‘import ‘lib-flexible‘import axios from ‘axios‘// 引入mockjsrequire(‘./mock/mock.js‘)// axios引入全局Vue.prototype.$http = axiosVue.config.productionTip = false/* eslint-disable no-new */new Vue({ ?el: ‘#app‘, ?router, ?components: { App }, ?template: ‘<App/>‘})

在组件中使用

<template> ?<div class="hello"> ???<h1>{{ msg }}</h1> ???<h2>mockjs测试</h2> ???<div class="adbox"> ???????<div class="wrapper" v-if="hideType" id=‘mydiv‘ ref = ‘mydiv‘> ????????</div> ???</div> ?</div></template><script>export default { ?name: ‘HelloWorld‘, ?data () { ???return { ?????msg: ‘Welcome to Your Vue.js App‘, ?????hideType: true, ???} ?}, ?mounted() { ??????this.getInfo() ?}, ?methods: { ?????getInfo() { ?????????this.$http.get(‘/getMockData‘) ?????????.then((res) => { ?????????????console.log(res) ?????????}) ?????????.catch(function (error) { ???????????console.log(error); ?????????}); ?????} ?}}</script><!-- Add "scoped" attribute to limit CSS to this component only --><style lang="less" scoped> ?h1, h2 { ?font-weight: normal;}ul { ?list-style-type: none; ?padding: 0; ?li { ?????display: inline-block; ?????padding: 0 10px; ?????margin: 0 10px; /*no*/ ???}}a { ?color: #42b983; ?font-size: 14px;}.adbox { ???position: relative;}.wrapper { ???position: absolute; ???top: 0; ???bottom: 0; ???background: #cccccc; ???margin: 0; ???width: 100%; ???opacity: 0.5; ???pointer-events: none; ???z-index: -10;}li:active { ???a:active { ???????color: red; ???}}.hide { ???pointer-events: none;}</style>

在控制台输出数据 可以看到 请求被拦截 并且返回了自己写的测试数据

mockjs 随机数据功能

刚才介绍了怎么使用mockjs拦截数据,接下来说下mockjs另一个核心内容,随机生成数据

mockjs 支持生成随机的文本、数字、布尔值、日期、邮箱、链接、图片、颜色等。

我们现在来改造下刚才的模拟数据

// mock.js// 引入mockjsconst Mock = require(‘mockjs‘);// 获取 mock.Random 对象const Random = Mock.Random;// 创建模拟数据let testData = function() { ???let dataList = []; ???for (let i = 0; i < 10; i++) { ???????let obj = { ???????????title: Random.csentence(10, 20), // ?Random.csentence( min, max ) 随机生成一段10-20长度的汉字字符串 ???????????picture: Random.dataImage(‘100x100‘, ‘测试图片‘), // Random.dataImage( size, text ) 生成一段随机的 Base64 图片编码 ???????} ???????dataList.push(obj) ???} ????return { ???????dataList: dataList ???}}Mock.mock( ‘/getMockData‘, ‘get‘ , testData)// Mock.mock( url, post/get , 返回的数据);

最终生成的数据

结语

mockjs官网中有很多的例子,可以随机生成多种数据,学会基本使用之后,可以到官网中查看各种类型数据的随机生成方法官网地址 http://mockjs.com/。

在vue-lic脚手架中安装mockjs,实现前后端分离开发

原文地址:https://www.cnblogs.com/slongs/p/10298896.html

知识推荐

我的编程学习网——分享web前端后端开发技术知识。 垃圾信息处理邮箱 tousu563@163.com 网站地图
icp备案号 闽ICP备2023006418号-8 不良信息举报平台 互联网安全管理备案 Copyright 2023 www.wodecom.cn All Rights Reserved