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

更新日期: 2019-01-22阅读: 2.8k标签: cli

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


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
// 引入mockjs
const 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‘
// 引入mockjs
require(‘./mock/mock.js‘)

// axios引入全局
Vue.prototype.$http = axios
Vue.config.productionTip = false

/* eslint-disable no-new */
new Vue({
  el: ‘#app‘,
  router,
  components: { App },
  template: ‘<App/>‘
})

在组件中使用

<template>
  <div>
    <h1>{{ msg }}</h1>
    <h2>mockjs测试</h2>
    <div>
        <div 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

// 引入mockjs
const 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/。

链接: https://www.fly63.com/article/detial/1858

采用vue-cli搭建一个Vue.js项目工程

Vue很优雅,没太多废话和周折,代码漂亮,思路清晰,大赞!上手比较快。Vue.js 因其性能、通用、易用、体积、学习成本低等特点已经成为了广大前端们的新宠。

使用nodejs编写命令行工具_编写自己的cli工具

编写自己的cli工具,一行命令,3秒钟进入coding状态!看完本文,你将学会如何从零开发一个cli项目,如何上传到github库,以及如何使用npm发布自己的包。

vue-cli e2e测试_运行 npm run e2e报错解决

vue init webpack 项目名字创建项目时,就可以选择单元测试,运行npm run e2e进行e2e单元测试了,结果发现出现很多错误,下面就总结下如何解决这些问题?

vue-cli3.0脚手架的使用_vue-cli3.0搭建与配置(vue.config.js)

vue-cli致力于将 Vue 生态中的工具基础标准化。它确保了各种构建工具能够基于智能的默认配置即可平稳衔接,这样你可以专注在撰写应用上,而不必花好几天去纠结配置的问题。与此同时,它也为每个工具提供了调整配置的灵活性,无需 eject

Vue-cli 3.0配置反向代理

vue-cli 3.0版本,配置代理Proxy,在项目根目录下新建vue.config.js,它是一个可选的配置文件,新建该文件,存放在项目根目录(将自动加载)中。配置代理如下:

改造vue-cli,使用mockjs搭建mock server

最近准备开发一款web应用,考虑到可能会有前后端并行开发的场景,所以决定使用mockjs做mock server。浏览官网文档时发现没有跑在webpack上的例子,索性自己找方法解决。当前端工程师需要独立于后端并行开发时,后端接口还没有完成,那么前端怎么获取数据?

vue-cli3 DllPlugin 提取公用库

vue 开发过程中,保存一次就会编译一次,如果能够减少编译的时间,哪怕是一丁点,也能节省不少时间。开发过程中个人编写的源文件才会频繁变动,而一些库文件我们一般是不会去改动的。如果能把这些库文件提取出来,就能减少打包体积,加快编译速度。本文主要讲述在 vue-cli3 中利用 DllPlugin 来进行预编译。

Angular CLI 使用教程指南参考

要安装Angular CLI你需要先安装node和npm,然后运行以下命令来安装最新的Angular CLI:注意:Angular CLI 需要Node 4.X 和 NPM 3.X 以上的版本支持。

vue-cli中使用jquery

在webpack.base.conf.js里加入(新版的可能找不到这个文件,你可以npm install webpack --save-dev进行手动安装),在module.exports的最后加入,在main.js 引入,新版直接在main.js 引入

解决Angular CLI找不到模块angular-devkit/build-angular的问题

Angular CLI 是 Angular 客户端命令行工具,提供非常多的命令来简化 Angular 的开发。今天执行“ng serve”命令时,竟然报找不到模块@angular-devkit/build-angular的错误。

点击更多...

内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!