IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> VUE 使用 mock -> 正文阅读

[JavaScript知识库]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'}) // 方式1

module.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: '<App/>',
  router,
  store
})

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

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

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

import Vue from 'vue'
import axios from 'axios'

const http = {
  install() {
    Vue.prototype.axios = axios;
  }
}

export default http

5. 运行前引入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. 发起请求

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

<template>
  <div>
    <button @click="getUserInfo">get user info</button>
    <button @click="login">login</button>
  </div>
</template>
<script>
import mock from '../../mock' // 方式1

export default {
  name: 'Mocker',
  data() {
    return {
      userInfo: {}
    }
  },
  methods: {
    getUserInfo() {
      this.axios.get('/user/userinfo')
      .then(res =>{
        console.log(res);
      })
      .catch(err => {
        console.log(err);
      });
    },
    login() {
      this.axios.post("/login").then(res => {
        console.log(res.data);
        if (res.data) {

        }
      })
    }
  }
}
</script>

Mocker.vue内容如上。

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

7. 运行结果

???????

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

点击按钮“get user info”,“login”分别出现数据表明mock成功。

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-08-19 18:55:10  更:2022-08-19 18:58:18 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/11 12:41:04-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码