vue+vux-ui+axios+mock搭建一个简单vue框架
2024-10-19 00:24:44
1.首先感谢同事
2.之前一直在做angularjs的项目,目前vue火热,所以自己搭建了一个的vue框架,在此作为记录
vue+vux-ui这里就不介绍了,有很多博客都写的很详细了。
下面简单记录下axios 和 mock
1.axios
<1> 安装axios
npm install axios
<2> 使用axios
1.因为有时候项目需要稍微封装一下axios,所以我这里并没有直接像官网那里在入口main.js直接引入axios
2.按照官网的要求,我在src目录下新建了一个文件axios,然后新建了两个js文件
1.axios.post.form.js
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,以上是本次记录!!!
最新文章
- redis安装
- 报表性能优化方案之单数据集分页SQL实现层式报表
- 【IIS】 网站优化
- 使用XML与远程服务器进行交互
- mkswap 把一个分区格式化成为swap交换区
- css水平居中总结
- VMWare中安装CentOS6.6不能上网的解决办法
- squid 代理服务器安装配置
- PHP文件目录copy
- mac10.9 设置vim tab
- mac php 版本切换
- 码农、黑客和2B程序员之间的区别
- Java开发笔记(七十六)如何预防异常的产生
- 使用C编程语言实现AVL树
- python提示AttributeError: &#39;NoneType&#39; object has no attribute &#39;append&#39;【转发】
- KeepAlived+Nginx 安装
- ORACLE 计算时间相减间隔
- ListView 添加 HeaderView常见错误
- mybatis3中@SelectProvider的使用技巧
- Delphi中,除了应用程序主窗口会显示在任务栏上,其它窗口默认都不会显示在任务栏.
热门文章
- php写入文件fwrite() 函数用法
- react阻止默认事件
- HiveSql调优经验
- canvas交互部分
- Vue2学习笔记:v-model指令
- ORAchk-数据库健康检查好帮手
- 新建一个去除storyboard的项目
- HTML5 JS &#23454;&#29616;&#27983;&#35272;&#22120;&#20840;&#23631;(F11&#30340;&#25928;&#26524;)
- multi_index_container
- 通过 Chrome 调试运行在 IOS-safari 上的页面