VUE 使用 mock

网友投稿 284 2022-08-23

VUE 使用 mock

mock使用背景

实际开发采用前后端分离形式,意味着后端API正在开发中,前端只需知道需要的数据格式即可进行开发,与后端开发同步进行。mock模拟后端提供api的调用,并返回数据。

mock使用步骤

1. 安装依赖

npm install mockjs

2. 建立文件夹

新建文件夹,并命名为mock。

3. mock文件中创建文件

const Mock = require('mockjs');const utils = require('./utils');Mock.mock('/login', {'name': '@name'}) // 方式1module.exports = function(app) { // 方式2 app.get('/user/userinfo', function(rep, res) { var json = utils.getJsonFile('./userInfo.json'); res.json(Mock.mock(json)) })}

index.js代码如上,需要注意的是mock的2种调用方式(这里有坑!!!)

{ "error": 0, "data": { "userid": "m900981", "username": "bill", "password": "...." }}

测试数据userinfo.json内容如上。

const fs = require('fs');const path = require('path');module.exports = { getJsonFile:function(filePath) { var json = fs.readFileSync(path.resolve(__dirname, filePath), 'utf-8'); return JSON.parse(json); }}

工具类utils.js

4. main.js引入

import Vue from 'vue'import App from './App'import VueRouter from 'vue-router'import router from './router'import axios from 'axios'import VueAxios from './vue-axios'import store from './store'//关闭Vue的生产提示Vue.config.productionTip = false//应用插件Vue.use(VueRouter)Vue.use(VueAxios, axios)/* eslint-disable no-new */new Vue({ el: '#app', components: { App }, template: '', router, store})

main.js引入axios(实际下载了axios依赖)。

main.js引入VueAxios,是因为新建了文件夹vue-axios。

vue-axios目录下的index.js内容如下。

import Vue from 'vue'import axios from 'axios'const = { install() { Vue.prototype.axios = axios; }}export default 运行前引入mock

修改webpack.dev.conf.js

... // these devServer options should be customized in /config/index.js devServer: { clientLogLevel: 'warning', historyApiFallback: { rewrites: [ { from: /.*/, to: path.posix.join(config.dev.assetsPublicPath, 'index.html') }, ], }, hot: true, contentBase: false, // since we use CopyWebpackPlugin. compress: true, host: HOST || config.dev.host, port: PORT || config.dev.port, open: config.dev.autoOpenBrowser, overlay: config.dev.errorOverlay ? { warnings: false, errors: true } : false, publicPath: config.dev.assetsPublicPath, proxy: config.dev.proxyTable, quiet: true, // necessary for FriendlyErrorsPlugin before: require('../mock'), // 划重点!!! watchOptions: { poll: config.dev.poll, } },...

添加配置before: require('../mock')。

运行项目,在项目启动前会引入mock。

6. 发起请求

实际使用是在组件中调用。

Mocker.vue内容如上。

需要注意的是:2种调用方式决定是否需要直接引入mock。

7. 运行结果

​​​​​​

打开浏览器后,F12打开调试窗口。

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:Python:关于高效使用字典的清单(Python字典的使用)
下一篇:中原银行实时风控体系建设实践
相关文章

 发表评论

暂时没有评论,来抢沙发吧~