首页 > 其他分享 >axios

axios

时间:2023-04-24 13:12:14浏览次数:31  
标签:function qs axios params error 默认值

引入axios

npm install axios

或者直接引入js文件

<script src="https://unpkg.com/axios/dist/axios.min.js"></script>

使用axios

// 通过 params 设置参数:
axios.get('/url', {
    params: {
      ID: 123
    }
  })
  .then(function (response) {
    console.log(response);
  })
  .catch(function (error) {
    console.log(error);
  });

axios回调函数中的this指向改变,无法访问data中的数据,所以要在axios之前把this赋值给that,在axios的then回调函数中使用that访问data。

使用application/x-www-form-urlencoded请求

const params = new URLSearchParams();
params.append('param1', 'value1');
params.append('param2', 'value2');
axios.post('/api', params);

URLSearchParams 不是所有的浏览器均支持。可以使用 qs 库来编码数据:

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

// Or in another way (ES6),
import qs from 'qs';
const data = { 'bar': 123 };
const options = {
  method: 'POST',
  headers: { 'content-type': 'application/x-www-form-urlencoded' },
  data: qs.stringify(data),
  url,
};
axios(options);

配置默认值

/*全局的axios默认值*/
axios.defaults.baseURL = 'url';
axios.defaults.headers.common['Authorization'] = AUTH_TOKEN;
axios.defaults.headers.post['Content-Type'] = 'application/x-www-form-urlencoded';

/*自定义实例默认值*/
//创建实例时设置配置的默认值
var instance = axios.create({
  baseURL: 'url'
});
//在实例已创建后修改默认值
instance.defaults.headers.common['Authorization'] = AUTH_TOKEN;

// 覆写库的超时默认值
// 现在,在超时前,所有请求都会等待 2.5 秒
instance.defaults.timeout = 2500;

// 为已知需要花费很长时间的请求覆写超时设置
instance.get('/longRequest', {
  timeout: 5000
});

拦截器

// 添加请求拦截器
axios.interceptors.request.use(function (config) {
    // 在发送请求之前做些什么
    return config;
  }, function (error) {
    // 对请求错误做些什么
    return Promise.reject(error);
  });

// 添加响应拦截器
axios.interceptors.response.use(function (response) {
    // 对响应数据做点什么
    return response;
  }, function (error) {
    // 对响应错误做点什么
    return Promise.reject(error);
  });

标签:function,qs,axios,params,error,默认值
From: https://www.cnblogs.com/aeolian/p/17349095.html

相关文章

  • axios发送请求
     1.浏览器前端向服务器发送http请求(请求报文)2.后台服务器接收到请求后,处理请求,向浏览器返回http响应(响应报文)3.浏览器端接收到响应,解析显示响应体或者调用监视回调函数  1.请求行:格式:methodurlGET/product_details?id=2  或者POST/login2.请求头(一般有多个)Host:......
  • Axios
    axios.get('url地址',{params:{参数1:值1,参数2:值2}}).then(function(response){console.log(response);}).catch(function(error){console.log(error);})axios({method:"get",url:"url地址",params:{参数......
  • axios response 返回数据,正则匹配替换里面文字,注意返回的数据可能多层嵌套的
    在做项目招标时,新切换个分支,用来竞标,大体流程类似,但其中有企业字段需要替换一个个页面替换也很麻烦,从接口返回数据上想想办法!tips:返回的数据格式,各种类型,各种嵌套的可能性都有;functionreplaceData(data){if(typeofdata==='string'){//使用正则表达式将'app......
  • vue:axios异步通讯
    由于Ajax需要对dom进行频繁的操作所以这里使用axios进行替代首先放上所有代码<body><divid="vue">{{info.name}}<av-bind:href="info.url">点我</a></div><!--到入vue.js--><scriptsrc="https://cdn.jsdelivr.net/npm/......
  • Axios
    Axios介绍:基于promise网络请求,实现异步获取请求数据。(无需重新加载页面完成局部数据刷新)示例一:<!--引入Axios--><scriptsrc="https://unpkg.com/axios/dist/axios.min.js"></script>​axios.get('/user',{  params:{//传参-> '/user?id=123'  ......
  • vue全家桶进阶之路47:Vue3 Axios拦截器封装成request文件
    可以将Axios拦截器封装成一个单独的request文件,以便在整个应用程序中重复使用。以下是一个示例,展示如何将Axios拦截器封装成一个request文件:1、创建一个名为request.js的新文件,并导入Axios:importaxiosfrom'axios';2、创建一个名为request的函数,并将其导出:这将创建一个名......
  • vue全家桶进阶之路46:Vue3 Axios拦截器和globalProperties全局设置
    在Vue.js3中,使用Axios与Vue.js2.x中类似,但是需要进行一些修改和更新,下面是Vue.js3中Axios的定义和使用方式:首先,你需要安装Axios和Vue.js3.x,可以使用npm或yarn等包管理工具安装:npminstallaxiosvue@next然后,在你的Vue.js3应用程序中,你可以使用以下代码来导入和使用Axio......
  • Module not found: Error: Can't resolve 'axios' in 'D:\BaiduSyncdisk\vue-cli-pr
    Modulenotfound:Error:Can'tresolve'axios'in'D:\BaiduSyncdisk\vue-cli-project\dc_vue3\src\utils'  因:没有安装axios插件在运行项目的地方npminstall--saveaxios解决办法 npminstall--saveaxios......
  • axios的二次封装(详解)
    一.首先让我们了解一下为什么要对axios进行二次封装?1,代码封装,重用性高,减少代码量,减低维护难度。2,统一处理一些常规的问题一劳永逸,如http错误。3,拦截请求和响应,提前对数据进行处理,如获取token,修改配置项。 安装axiosnpm下载npminstallaxios下载完成之后在main.js中全局......
  • axios
    axios使用参考:http://www.axios-js.com/zh-cn/docs/index.html#axios-API定时:https://blog.csdn.net/weixin_43574035/article/details/126233221......