1.首先感谢同事javascript
2.以前一直在作angularjs的项目,目前vue火热,因此本身搭建了一个的vue框架,在此做为记录vue
vue+vux-ui这里就不介绍了,有不少博客都写的很详细了。java
下面简单记录下axios 和 mockios
1.axiosangularjs
<1> 安装axiosnpm
npm install axios
<2> 使用axiosjson
1.由于有时候项目须要稍微封装一下axios,因此我这里并无直接像官网那里在入口main.js直接引入axiosaxios
2.按照官网的要求,我在src目录下新建了一个文件axios,而后新建了两个js文件后端
1.axios.post.form.jsapi
2.axios.post.json.js
这里记录第个axios.post.form.js文件:
1.首先引入axios
import axios from 'axios'
2.自定义配置新建一个 axios 实例
const axiosPostForm = axios.create({ baseURL: "", // api的base_url timeout: 5000, // request timeout headers: { 'Content-Type': 'application/json' } })
3.建立请求过滤器
axiosPostForm.interceptors.request.use( config => { //根据实际项目修改拦截器 console.log(config); config.data = config.data||{} return config; }, error =>{ return Promise.reject(error); });
4.建立响应过滤器
axiosPostForm.interceptors.response.use( response => { console.log(response); return response.data }, error => { return Promise.reject(error); })
5.返回封装以后的axiosPostForm
export default axiosPostForm
下面是完整的这个JS文件
import axios from 'axios' const axiosPostForm = axios.create({ baseURL: "", // api的base_url timeout: 5000, // request timeout headers: { 'Content-Type': 'application/json' } }) axiosPostForm.interceptors.request.use( config => { //根据实际项目修改拦截器 console.log(config); config.data = config.data||{} return config; }, error =>{ return Promise.reject(error); }); axiosPostForm.interceptors.response.use( response => { console.log(response); return response.data }, error => { return Promise.reject(error); }) export default axiosPostForm
<3> 接下来须要在入口main.js中引入该封装以后的axiosPostForm,以便全局使用
//引入axios
import axiosPostForm from './axios/axios.post.form'
//在vue的原型链上增长axiosPostForm
Vue.prototype.$axiosPostForm = axiosPostForm;
<4>在你的应用组建就能够直接使用封装以后的$axiosPostForm了,一下代码:
this.$axiosPostForm({ method: 'post', url:"/userInfo", //这里是你的后端地址,若是没有,请看下面引入mock挡板数据 data: { id: '100001', name: 'xxxxxx' } }).then(function (res) { console.log(res) })
以上,一个完整的axios服务已经完成,下面引入mock挡板
2.mockjs
<1> 安装mockjs
npm install mockjs
<2> 在src文件新建mock文件夹
1.在mock文件夹目录下,新建两个文件,一个index.js,一个usermock.js
2.首先先在usermock.js,新建挡板数据,并暴露出来,代码以下:
export default { getUserInfo:()=>{ return { code:"0", message:"访问成功", data:[{ id:1, licNumber:'陕A79898', color:1, buyTime:'2017-04-01' }, { id:2, licNumber:'陕A2222', color:1, buyTime:'2017-04-01' }, { id:3, licNumber:'陕A3333', color:1, buyTime:'2017-04-01' }] } } }
<3> 在mock文件夹下的index.js中引入mock和上面写的usermock.js,代码以下
import Mock from 'mockjs'; import userInfo from "./usermock" Mock.mock("/userInfo",'post',userInfo.getUserInfo()); export default Mock
<4>在入口文件main.js里面加入对Mock的控制(是否使用mock挡板)
const mock = true; if(mock){ require("./mock"); }
<5> 以上,在你的应用组建就能够直接使用
this.$axiosPostForm({ method: 'post', url:"/userInfo", data: { id: '100001', name: 'xxxxxx' } }).then(function (res) { console.log(res) })
over,以上是本次记录!!!