客户端项目中有一个小需求“我的卡券”,有单独入口,所以综合考虑之后,采用了vue来实现,因为是初次使用,导致了选型不当,先用了SUI-Mobile来搭建页面,当决定使用vue的时候,页面也搭建完毕了,最终结果就是使用vue+SUI-Mobile+vue-router实现了这么一个小需求。

  中间考虑使用axios来作异步请求的,但是很不幸的是,在请求接口的时候axios报了404,由于有方便替代的Zepto封装的ajax,所以当时直接改用ajax来请求了,也没有去研究究竟什么原因导致的axios请求报错的。这段时间,相对不那么忙的时候,想到这个问题,就回过头来把这块的vue代码做了一个简单的review,修改了一些明显不那么合适的vuejs的代码,然后就将目标定在了异步请求上面。

  先看一下,正确的ajax代码,真实的接口就以变量interface替代:

    getData(){
var _this = this;
$.showIndicator();
var ctx = GetQueryString("path");
$.ajax({
type: "post",
url:ctx+interface,
data:{"coupon_status":1},
success:function(data){
$.hideIndicator();
if(data.ret_code==1){
//网络异常
$.alert('网络异常');
}else{
_this.list = data.ticketlist;
}
}
})
}

  除了真实的接口,这就是之前使用的能够正常请求的ajax请求。

  下面改造为axios格式的 

    getData(){
var _this = this;
var ctx = GetQueryString("path");
$.showIndicator();
axios.post(ctx + interface, {"coupon_status":1}).then((res)=>{
$.hideIndicator();
if(data.ret_code==1){
//网络异常
$.alert('网络异常');
}else{
_this.list = data.ticketlist;
}
})
}

  一眼看过去,除了将ajax改为axios,我相信大多数人是看不出有什么问题的

但是事实就是:报错了,而且报404错误

不明原因的ctx获取的值出现了重复的educloud,而在ajax请求时却是正常的,导致了接口报404。

通过翻阅axios在GitHub网站api,引用原文You can specify config defaults that will be applied to every request.就是对每一个请求接口设定一些默认配置。

axios.defaults.baseURL = ctx;

  再请求一次接口

  

  不再报404错误了,而是400,那400是什么呢?

400错误是由于不正确的请求造成的,说明正在搜索的网页可能已经删除、更名或暂时不可用。

  关键在于请求不正确,说明接口已经请求到了,但是当前请求接口有问题,然而ajax请求是正常的,那么问题又在什么地方呢?如果经验比较丰富一点的,很容易联想到是不是参数有问题?

  继续翻看api,发现

var qs = require('qs');
axios.post('/foo', qs.stringify({ 'bar': 123 }));

  这里对参数进行了一下处理,那么就照着来吧

    import axios from "axios"
var ctx = GetQueryString("path");
var qs = require('qs');
axios.defaults.baseURL = ctx;
getData(){
var _this = this;
$.showIndicator();
axios.post(interface, qs.stringify({
"coupon_status":0
})).then(function (response) {
console.log(response)
var data = response.data;
$.hideIndicator();
if(data.ret_code==1){
//网络异常
$.alert('网络异常');
}else{
_this.list = data.ticketlist;
}
}).catch((err)=>{
console.log(err)
})

  很荣幸,问题解决了,接口已经可以正确返回数据了。

  总结一下:

  axios在调用接口产生问题时,一方面可能是因为接口url不对,那么通过配置默认的baseURL,另一方面,考虑post参数问题,不能直接传递一个JS对象,而需要通过qs.stringify(对象)转换一下。

  试图使用JSON.stringify()转换,很不幸,不可以。 

  

  

vue搭配axios踩坑的更多相关文章

  1. vue cli+axios踩坑记录+拦截器使用,代理跨域proxy(更新)

    16319 1.首先axios不支持vue.use()方式声明使用,看了所有近乎相同的axios文档都没有提到这一点建议方式 在main.js中如下声明使用 import axios from 'ax ...

  2. vue cli+axios踩坑记录+拦截器使用,代理跨域proxy

    1.首先axios不支持vue.use()方式声明使用,看了所有近乎相同的axios文档都没有提到这一点 建议方式 在main.js中如下声明使用 import axios from 'axios'; ...

  3. Vue中axios踩坑之路-POST传参

    https://blog.csdn.net/call_me_fly/article/details/79012581

  4. vue配置环境踩坑

    Vue 环境配置踩坑 目录 Vue 环境配置踩坑 windows下cnpm -v :无法将"cnpm"项识别为 cmdlet.函数.脚本文件或可运行程序的名称. windows下c ...

  5. axios踩坑记录+拦截器使用+vue cli代理跨域proxy+webpack打包部署到服务器

    1.小小的提一下vue cli脚手架前端调后端数据接口时候的本地代理跨域问题,如我在本地localhost访问接口http://40.00.100.100:3002/是要跨域的,相当于浏览器设置了一道 ...

  6. vue+ vue-router + webpack 踩坑之旅

    说是踩坑之旅 其实是最近在思考一些问题 然后想实现方案的时候,就慢慢的查到这些方案   老司机可以忽略下面的内容了 1)起因  考虑到数据分离的问题  因为server是express搭的   自然少 ...

  7. [ vue ] quasar框架踩坑:在vue文件外导入路由,执行router.push('/')没有效果

    问题描述: 1. 如图所示的项目结构目录, axios.js 文件负责拦截全局请求和回复,我在拦截回复的代码中写了:如果服务器回复了一个401错误,则执行Router.push('/'),但是该方法失 ...

  8. vue + element-ui 制作tab切换(切换vue组件,踩坑总结)

    本篇文章使用vue结合element-ui开发tab切换vue的不同组件,每一个tab切换的都是一个新的组件. 1.vue如何使用element-ui 上一篇文章已经分享了如何在vue中使用eleme ...

  9. vue项目打包踩坑记

    基于webpack+vue-cli下的vue项目打包命令是 npm run build ,等待打包完成后在根目录生成dist文件夹,里面包含了所有项目相关的内容. 注意:需要完整版的vue-cli项目 ...

随机推荐

  1. Scrapy 设置请求头

    爬虫的过程有些网站设置反盗链,需要我们在请求头中添加下,修改settings.py文件中添加 DEFAULT_REQUEST_HEADERS = { 'Accept': 'text/html,appl ...

  2. 红外协议之NEC协议

    NEC协议载波:38khz 其逻辑1与逻辑0的表示如图所示: 逻辑1为2.25ms,脉冲时间560us:逻辑0为1.12ms,脉冲时间560us.所以我们根据脉冲时间长短来解码.推荐载波占空比为1/3 ...

  3. tomcat端口号被占用的问题

    错误原因:8080端口被其他的应用占用! 在网上查了下解决方案,有些说在任务管理窗口关闭javaw.exe,有些说shutdown一下tomcat,亲测在某些场合下可用. 下面是摘自其它博客园里文章的 ...

  4. Xshell配置ssh使用密钥公钥(publice key)登录

    ssh登录提供两种认证方式:口令(密码)认证方式和密钥认证方式.其中口令(密码)认证方式是我们最常用的一种,这里介绍密钥认证方式登录到linux/unix的方法. 使用密钥登录分为3步:1.生成密钥( ...

  5. Windows XP Professional产品序列号

    BX6HT-MDJKW-H2J4X-BX67W-TVVFG产品密钥:FCKGW-RHQQ2-YXRKT-8TG6W-2B7Q8产品密钥:CCC64-69Q48-Y3KWW-8V9GV-TVKRM Wi ...

  6. JGit与远程仓库链接使用的两种验证方式(ssh和https)

    JGit是使用JAVA的API来操控Git仓库的库,由Eclipse公司维护.他提供的API分成两个层次,底层命令和高层命令.底层API是直接作用于低级的仓库对象,高层的API是一个面向普通用户级别功 ...

  7. AS3 内存基础

    1:获取一个对象的字节数: var str:String="ddd啊"; var byte:ByteArray=new ByteArray(); byte.writeMultiBy ...

  8. 写在vue总结之前(一)

    在大概2016年6月吧,知道了vue,博客园有个博主用vue写了一个不算完整的博客园app,做出来的效果相比博客园原本的app看上去要华丽很多,那时候做前端还没多久,很多东西都不知道,别人说用vue开 ...

  9. LinkedList的自定义实现

    一.背景 LinkedList双向链表: 代码: Node.java: package com.cy.collection; public class Node { Node previous; // ...

  10. Java性能调优:利用JMC分析性能

    Java性能调优作为大型分布式系统提供高性能服务的必修课,其重要性不言而喻. 好的分析工具能起到事半功倍的效果,利用分析利器JMC.JFR,可以实现性能问题的准确定位. 本文主要阐述如何利用JMC分析 ...