vue中封装axios方法
axios基本配置 使用方法
- import axios from 'axios'
- // 创建axios实例
- const service = axios.create({
- baseURL: process.env.BASE_API, // node环境的不同,对应不同的baseURL
- timeout: 5000, // 请求的超时时间
- //设置默认请求头,使post请求发送的是formdata格式数据// axios的header默认的Content-Type好像是'application/json;charset=UTF-8',我的项目都是用json格式传输,如果需要更改的话,可以用这种方式修改
- // headers: {
- // "Content-Type": "application/x-www-form-urlencoded"
- // },
- withCredentials: true // 允许携带cookie
- })
封装get和post方法
- import axios from 'axios';
- const serverconfig = require('../../static/serverconfig.json') // 这个json文件中配置接口根目录地址
- class Axios{
- getUrl(url){
- return `${serverconfig.ApiUrl}${url}`; // 获取完整的接口地址
- };
- // post 请求
- postServer(opt) {
- const _axios = axios.create({
- timeout: 10000
- });
- let data = {};
- if (opt.data) {
- data = opt.data;
- }
- _axios.post(opt.url, data).then((response) => {
- console.log(response);
- if(response.data.status === 'error'){
- // 这里用layer弹层插件
- layer.open({
- content: 'error:' + response.data.hotelInfo
- ,skin: 'msg'
- ,time: 2 //2秒后自动关闭
- });
- if (opt.onFailed) {
- opt.onFailed(response);
- }
- return;
- }
- if (opt.onSuccess) {
- opt.onSuccess(response);
- }
- }).catch(error => {
- if (opt.onFailed) {
- opt.onFailed(error);
- }
- if (!error.response.data.success) {
- alert(error.response.data.error.message);
- // return;
- }
- });
- }
- // get 请求
- getServer(opt) {
- const _axios = axios.create({
- timeout:10000
- });
- let data = {};
- if (opt.data) {
- data = opt.data;
- }
- _axios.get(opt.url, {params: data}).then((response) => {
- if (opt.onSuccess) {
- opt.onSuccess(response);
- }
- }).catch(error => {
- if (opt.onFailed) {
- opt.onFailed(error);
- }
- });
- }
- setData(opt) {
- let data = {};
- if (opt.data) {
- data = opt.data;
- }
- return data;
- }
- }
- export default Axios;
封装接口
- hotel.service.js
- import Axios from './axios.service'
- const AxiosMethods = new Axios();
- sendQueryServer(opt){
- const data = AxiosMethods .setData(opt);
- const url = AxiosMethods .getUrl('/Home/Query');
- AxiosMethods .postServer({url, data, onSuccess: opt.onSuccess,
- onFailed: opt.onFailed});
- }
- }
页面调用query.vue
- import HotelServer from "@/service/hotel.service"
- const hotelServer = new HotelServer();
- methods:{
- _sendQueryServer() {
- const loadingIndex = this.loadingShow()
- hotelServer.sendQueryServer({
- onSuccess: (res) => {
- layer.close(loadingIndex)
- console.log(res)
- },
- onFailed: (res) => {
- layer.close(loadingIndex)
- }
- })
- }
vue中封装axios方法的更多相关文章
- Vue中封装axios
参考: https://www.jianshu.com/p/7a9fbcbb1114 https://www.cnblogs.com/dreamcc/p/10752604.html 一.安装axios ...
- vue中封装公共方法,全局使用
1.以封装的合并单元格为例,首先建立一个util.js 2.在main.js中引用 3.直接在使用该方法的地方调用就可以了
- Vue中封装axios组件实例
首先要创建一个网络模块network文件夹 里面要写封装好的几个组件 在config.js里面这样写 在index.js要这样写 core.js文件里面内容如下 然后要在main.js文件里面要设置 ...
- vue中采用axios发送请求及拦截器
这几天在使用vue中axios发送get请求的时候很顺手,但是在发送post请求的时候老是在成功的回调函数里边返回参数不存在,当时就纳闷了,经过查阅资料,终于得到了解决方案,在此做一总结: 首先我们在 ...
- vue中使用axios进行http通信
1.安装 npm install axios 2.在main.js中全局注册 // axios不可以通过use引入,可以通过修改vue原型链 import axios from 'axios' Vue ...
- vue中代理实现方法
vue中代理实现方法如下: const path = require('path'); function resolve(dir) { return path.join(__dirname, dir) ...
- vue中使用axios与axios的请求响应拦截
VUE中使用Axios axios的安装 npm install axios vue-axios axios在vue的配置与使用 在main.js中引入axios和vue-axios import a ...
- vue中对axios进行封装
在刚结束的项目中对axios进行了实践(好不容易碰上一个不是jsonp的项目), 以下为在项目中对axios的封装,仅封装了post方法,因为项目中只用到了post,如有需要请自行进行修改 src/c ...
- vue中的axios封装
import axios from 'axios'; import { Message } from 'element-ui'; axios.defaults.timeout = 5000;axios ...
随机推荐
- javascript控制服务器控件实例一
最近多个页面需要加载一些下拉列表框,供用户选择,原来都是在服务器端进行加载应运用.最后由于 业务逻辑方面的考虑,需要将DropDownList的部分功能放到客户端实现.现在下拉列表的功能使用起来感 觉 ...
- Java 二维码--转载
周末试用下Android手机的二维码扫描软件,扫描了下火车票.名片等等,觉得非常不错很有意思的.当然Java也可以实现这些,现在就分享下如何简单用Java实现二维码中QRCode的编码和解码(可以手机 ...
- perl 中的哈希赋值
在perl 中,通过代码动态的给哈希赋值,是最常见的应用场景,但是有些情况下,我们事先知道一些信息,当需要把这些信息存放进一个哈希的时候,直接给哈希赋值就好: 哈希的key不用说,就是一个字符串,关键 ...
- fastx tookit 操作fasta/fastq 文件 (1)
准备测试文件 test.fq, 包含4条fastq 文件,碱基编码格式为phred64; @FC12044_91407_8_200_406_24 NTTAGCTCCCACCTTAAGATGTTTA + ...
- asp.net 后端验证
using EntryRegistration.Filters; using EntryRegistration.Models.Entity; using System; using System.C ...
- MetaSploit Pro 下载地址
Windows: https://downloads.metasploit.com/data/releases/metasploit-latest-windows-installer.exe Linu ...
- PHP删除目录及目录下所有文件或删除指定文件
PHP删除目录及目录下所有文件或删除指定文件 <?php header("content-type:text/html;charset=utf-8"); /** * 删除目录 ...
- UIScrollView 的代理方法简单注解
//减速停止了时执行,手触摸时执行执行 - (void)scrollViewDidEndDecelerating:(UIScrollView *)scrollView; //只要滚动了就会触发 ...
- c++ 向main传递参赛
1.今天写了个批处理文件 准备向main传递参赛 发现在vs2008运行正常 vs2010运行只有首字母 2.需要在项目--属性--常规-字符集里面设置成多字节就好了,以前是unicode 3.因为 ...
- myeclipse 配置
1.配置java 新建系统变量JAVA_HOME 和CLASSPATH 变量名:JAVA_HOME 变量值:C:\Program Files\Java\jdk1.7.0变量名:CLASSPATH 变量 ...