axios基本配置 使用方法

  1. import axios from 'axios'
  2.  
  3. // 创建axios实例
  4. const service = axios.create({
  5. baseURL: process.env.BASE_API, // node环境的不同,对应不同的baseURL
  6. timeout: 5000, // 请求的超时时间
  7. //设置默认请求头,使post请求发送的是formdata格式数据// axios的header默认的Content-Type好像是'application/json;charset=UTF-8',我的项目都是用json格式传输,如果需要更改的话,可以用这种方式修改
  8. // headers: {
  9. // "Content-Type": "application/x-www-form-urlencoded"
  10. // },
  11. withCredentials: true // 允许携带cookie
  12. })

封装get和post方法

  1. import axios from 'axios';
  2. const serverconfig = require('../../static/serverconfig.json') // 这个json文件中配置接口根目录地址
  3.  
  4. class Axios{
  5. getUrl(url){
  6. return `${serverconfig.ApiUrl}${url}`; // 获取完整的接口地址
  7. };
  8.  
  9. // post 请求
  10. postServer(opt) {
  11. const _axios = axios.create({
  12. timeout: 10000
  13. });
  14. let data = {};
  15. if (opt.data) {
  16. data = opt.data;
  17. }
  18. _axios.post(opt.url, data).then((response) => {
  19. console.log(response);
  20. if(response.data.status === 'error'){
  21. // 这里用layer弹层插件
  22. layer.open({
  23. content: 'error:' + response.data.hotelInfo
  24. ,skin: 'msg'
  25. ,time: 2 //2秒后自动关闭
  26. });
  27. if (opt.onFailed) {
  28. opt.onFailed(response);
  29. }
  30. return;
  31. }
  32. if (opt.onSuccess) {
  33. opt.onSuccess(response);
  34. }
  35. }).catch(error => {
  36. if (opt.onFailed) {
  37. opt.onFailed(error);
  38. }
  39. if (!error.response.data.success) {
  40. alert(error.response.data.error.message);
  41. // return;
  42. }
  43.  
  44. });
  45. }
  46.  
  47. // get 请求
  48. getServer(opt) {
  49. const _axios = axios.create({
  50. timeout:10000
  51. });
  52. let data = {};
  53. if (opt.data) {
  54. data = opt.data;
  55. }
  56. _axios.get(opt.url, {params: data}).then((response) => {
  57. if (opt.onSuccess) {
  58. opt.onSuccess(response);
  59. }
  60. }).catch(error => {
  61. if (opt.onFailed) {
  62. opt.onFailed(error);
  63. }
  64. });
  65. }
  66.  
  67. setData(opt) {
  68. let data = {};
  69. if (opt.data) {
  70. data = opt.data;
  71. }
  72. return data;
  73. }
  74.  
  75. }
  76.  
  77. export default Axios;

封装接口

  1. hotel.service.js
  1. import Axios from './axios.service'
  2. const AxiosMethods = new Axios();
  3. sendQueryServer(opt){
  4. const data = AxiosMethods .setData(opt);
  5. const url = AxiosMethods .getUrl('/Home/Query');
  6. AxiosMethods .postServer({url, data, onSuccess: opt.onSuccess,
  7. onFailed: opt.onFailed});
  8. }
  9. }

页面调用query.vue

  1. import HotelServer from "@/service/hotel.service"
  2.  
  3. const hotelServer = new HotelServer();
  4.  
  5. methods:{
  6. _sendQueryServer() {
  7. const loadingIndex = this.loadingShow()
  8. hotelServer.sendQueryServer({
  9. onSuccess: (res) => {
  10. layer.close(loadingIndex)
  11. console.log(res)
  12. },
  13. onFailed: (res) => {
  14. layer.close(loadingIndex)
  15. }
  16. })
  17. }

vue中封装axios方法的更多相关文章

  1. Vue中封装axios

    参考: https://www.jianshu.com/p/7a9fbcbb1114 https://www.cnblogs.com/dreamcc/p/10752604.html 一.安装axios ...

  2. vue中封装公共方法,全局使用

    1.以封装的合并单元格为例,首先建立一个util.js 2.在main.js中引用 3.直接在使用该方法的地方调用就可以了

  3. Vue中封装axios组件实例

    首先要创建一个网络模块network文件夹  里面要写封装好的几个组件 在config.js里面这样写 在index.js要这样写 core.js文件里面内容如下 然后要在main.js文件里面要设置 ...

  4. vue中采用axios发送请求及拦截器

    这几天在使用vue中axios发送get请求的时候很顺手,但是在发送post请求的时候老是在成功的回调函数里边返回参数不存在,当时就纳闷了,经过查阅资料,终于得到了解决方案,在此做一总结: 首先我们在 ...

  5. vue中使用axios进行http通信

    1.安装 npm install axios 2.在main.js中全局注册 // axios不可以通过use引入,可以通过修改vue原型链 import axios from 'axios' Vue ...

  6. vue中代理实现方法

    vue中代理实现方法如下: const path = require('path'); function resolve(dir) { return path.join(__dirname, dir) ...

  7. vue中使用axios与axios的请求响应拦截

    VUE中使用Axios axios的安装 npm install axios vue-axios axios在vue的配置与使用 在main.js中引入axios和vue-axios import a ...

  8. vue中对axios进行封装

    在刚结束的项目中对axios进行了实践(好不容易碰上一个不是jsonp的项目), 以下为在项目中对axios的封装,仅封装了post方法,因为项目中只用到了post,如有需要请自行进行修改 src/c ...

  9. vue中的axios封装

    import axios from 'axios'; import { Message } from 'element-ui'; axios.defaults.timeout = 5000;axios ...

随机推荐

  1. javascript控制服务器控件实例一

    最近多个页面需要加载一些下拉列表框,供用户选择,原来都是在服务器端进行加载应运用.最后由于 业务逻辑方面的考虑,需要将DropDownList的部分功能放到客户端实现.现在下拉列表的功能使用起来感 觉 ...

  2. Java 二维码--转载

    周末试用下Android手机的二维码扫描软件,扫描了下火车票.名片等等,觉得非常不错很有意思的.当然Java也可以实现这些,现在就分享下如何简单用Java实现二维码中QRCode的编码和解码(可以手机 ...

  3. perl 中的哈希赋值

    在perl 中,通过代码动态的给哈希赋值,是最常见的应用场景,但是有些情况下,我们事先知道一些信息,当需要把这些信息存放进一个哈希的时候,直接给哈希赋值就好: 哈希的key不用说,就是一个字符串,关键 ...

  4. fastx tookit 操作fasta/fastq 文件 (1)

    准备测试文件 test.fq, 包含4条fastq 文件,碱基编码格式为phred64; @FC12044_91407_8_200_406_24 NTTAGCTCCCACCTTAAGATGTTTA + ...

  5. asp.net 后端验证

    using EntryRegistration.Filters; using EntryRegistration.Models.Entity; using System; using System.C ...

  6. MetaSploit Pro 下载地址

    Windows: https://downloads.metasploit.com/data/releases/metasploit-latest-windows-installer.exe Linu ...

  7. PHP删除目录及目录下所有文件或删除指定文件

    PHP删除目录及目录下所有文件或删除指定文件 <?php header("content-type:text/html;charset=utf-8"); /** * 删除目录 ...

  8. UIScrollView 的代理方法简单注解

    //减速停止了时执行,手触摸时执行执行 - (void)scrollViewDidEndDecelerating:(UIScrollView *)scrollView;    //只要滚动了就会触发 ...

  9. c++ 向main传递参赛

    1.今天写了个批处理文件 准备向main传递参赛  发现在vs2008运行正常 vs2010运行只有首字母 2.需要在项目--属性--常规-字符集里面设置成多字节就好了,以前是unicode 3.因为 ...

  10. myeclipse 配置

    1.配置java 新建系统变量JAVA_HOME 和CLASSPATH 变量名:JAVA_HOME 变量值:C:\Program Files\Java\jdk1.7.0变量名:CLASSPATH 变量 ...