ajax

Vuejs 并没有直接处理ajax的组件,但可以使用axios或vue-resource组件实现对异步请求的操作。

使用axiosvue-resource组件实现对异步请求的操作。

vue-resource

vue-resource是Vue.js的插件提供了使用XMLHttpRequest或JSONP进行Web请求和处理响应的服务。 当vue更新到2.0之后,作者就宣告不再对vue-resource更新,而是推荐axios。

axios

Axios 是一个基于 promise 的 HTTP 库,可以用在浏览器和 node.js 中。

axios的github地址:https://github.com/axios/axios

# 如果使用npm则可以如下安装
npm install axios

或者也可以直接使用公共的CDN(内容分发网络)服务:

<!-- 开发环境版本,包含了用帮助的命令行警告 -->
<script src="https://unpkg.com/axios/dist/axios.min.js"></script>

axios的作用

  1. 发送异步请求获取数据

  2. 常见的方法:

    1. get、post

      常用的就是get和post

    2. 在发送的时候可以指定参数(地址、请求方式和请求头部信息);

    3. 返回数据结构(data/status/statusText/headers/config)

      data返回的数据都在这个里面

方法说明

config请求配置

这些是创建请求时可以用的配置选项。只有 url 是必需的。如果没有指定 method ,请求将默认使用 get 方法。

{// `url` 是用于请求的服务器 URLurl: '/user',// `method` 是创建请求时使用的方法method: 'get', // 默认是 get// `baseURL` 将自动加在 `url` 前面,除非 `url` 是一个绝对 URL。// 它可以通过设置一个 `baseURL` 便于为 axios 实例的方法传递相对 URLbaseURL: 'https://some-domain.com/api/',// `transformRequest` 允许在向服务器发送前,修改请求数据// 只能用在 'PUT', 'POST' 和 'PATCH' 这几个请求方法// 后面数组中的函数必须返回一个字符串,或 ArrayBuffer,或 StreamtransformRequest: [function (data) {// 对 data 进行任意转换处理return data;}],// `transformResponse` 在传递给 then/catch 前,允许修改响应数据transformResponse: [function (data) {// 对 data 进行任意转换处理return data;}],// `headers` 是即将被发送的自定义请求头headers: {'X-Requested-With': 'XMLHttpRequest','Content-Type': 'application/json'},// `params` 是即将与请求一起发送的 URL 参数// 必须是一个无格式对象(plain object)或 URLSearchParams 对象params: {ID: 12345},// `data` 是作为请求主体被发送的数据// 只适用于这些请求方法 'PUT', 'POST', 和 'PATCH'// 在没有设置 `transformRequest` 时,必须是以下类型之一:// - string, plain object, ArrayBuffer, ArrayBufferView, URLSearchParams// - 浏览器专属:FormData, File, Blob// - Node 专属: Streamdata: {firstName: 'Fred'},// `timeout` 指定请求超时的毫秒数(0 表示无超时时间)// 如果请求话费了超过 `timeout` 的时间,请求将被中断timeout: 1000,// `withCredentials` 表示跨域请求时是否需要使用凭证withCredentials: false, // 默认的// `responseType` 表示服务器响应的数据类型,可以是 'arraybuffer', 'blob', 'document',
'json', 'text', 'stream'responseType: 'json', // 默认的// `maxContentLength` 定义允许的响应内容的最大尺寸maxContentLength: 2000,// `validateStatus` 定义对于给定的HTTP 响应状态码是 resolve 或 reject promise 。如果`validateStatus` 返回 `true` (或者设置为 `null` 或 `undefined`),promise 将被 resolve; 否则,promise 将被 rejectevalidateStatus: function (status) {return status >= 200 && status < 300; // 默认的},// `maxRedirects` 定义在 node.js 中 follow 的最大重定向数目
// 如果设置为0,将不会 follow 任何重定向maxRedirects: 5 // 默认的
}

响应结构

{// `data` 由服务器提供的响应data: {},// `status` 来自服务器响应的 HTTP 状态码status: 200,// `statusText` 来自服务器响应的 HTTP 状态信息statusText: 'OK',// `headers` 服务器响应的头headers: {},// `config` 是为请求提供的配置信息config: {}
}

axios方法

不能以静态文件去访问数据,这样会报错;需要以服务器的方式去访问才不会报错

  • 在这里演示的是静态的一个json文件,访问是服务器地址也是可以的,这三种方式(axios、get和post方法)都可以,做法也是一模一样

    注意:如果使用axios访问跨域数据的时候,只需要在服务提供方中,在方法上面使用SpringMVC的跨域注解即可解决数据跨域问题。如在方法上添加:@CrossOrigin(origins = “http://localhost:10000”)
    如果请求的地址是使用了网关,那么在网关服务器上配置跨域就可以了;不能同时在网关服务器和服务提供服务工程中同时配置。

    跨域:在前端js中如果发送异步请求的话,请求的地址与当前服务器的ip或者端口号不同都是跨域请求,可以使用如下方式在服务器端进行配置:

  • 测试代码:

    <!DOCTYPE html>
    <html lang="en">
    <head><meta charset="UTF-8"><title>测试</title><script src="node_modules/vue/dist/vue.js"></script><script src="js/axios.min.js"></script>
    </head>
    <body><div id="va"><ul><li v-for="(user,index) in users" :key="index">{{index}}--{{user.name}}--{{user.age}}--{{user.gender}}</li></ul></div>
    <script>//父组件var va = new Vue({//创建一个vue实例el:"#va",//el即element,要渲染的页面元素data: {users:[]},//使用钩子函数初始化加载数据created(){//加载数据axios({method:"get",url: "data.json"}).then((res)=>{//加载数据成功,在这个{}里面对res数据进行处理console.log(res);//将数据赋值到vue实例中的数据属性users//不能使用this,this在axios回调函数中表示的是窗口,不是vue实例va.users = res.data;}).catch(error=>{//加载数据失败alert(error);//失败就弹出数据});}});
    </script>
    </body>
    </html>
    
  • data.json的数据内容:

    [{"name":"张三","age":8,"gender":"男"},{"name":"李四","age":12,"gender":"女"},{"name":"王五","age":4,"gender":"男"}
    ]
    
  • 效果1:使用静态文件去访问,会报错,按shift打开

  • 效果2:直接打开,这样是使用服务器去打开,这样不会错误

get方法

示例中的axios操作部分修改为如下,

  • 就修改了下面的这些代码,
  • 最后的实现效果一样
axios.get("data.json").then((res)=>{//加载数据成功,在这个{}里面对res数据进行处理console.log(res);//将数据赋值到vue实例中的数据属性users//不能使用this,this在axios回调函数中表示的是窗口,不是vue实例va.users = res.data;
}).catch(error=>{//加载数据失败alert(error);//失败就弹出数据
});

post方法

示例中的axios操作部分修改为如下,

  • 就修改了下面的这些代码,
  • 最后的实现效果一样
axios.post("data.json").then((res)=>{//加载数据成功,在这个{}里面对res数据进行处理console.log(res);//将数据赋值到vue实例中的数据属性users//不能使用this,this在axios回调函数中表示的是窗口,不是vue实例va.users = res.data;
}).catch(error=>{//加载数据失败alert(error);//失败就弹出数据
});

axios实现异步请求相关推荐

  1. 如何使用Axios发送异步请求?

    首先,让我们来介绍一下Axios.Axios是一个基于Promise的HTTP客户端,它可以帮助我们轻松地发送异步请求.它支持所有现代浏览器(包括IE8+),并且还提供了Node.js的版本. 那么, ...

  2. axios发送异步请求文件,并下载文件到本地

    背景:业务上有这样一个需求: 一个列表数据,通过条件查询筛选出目标列表数据,然后将这些目标列表数据导出到本地 后端提供了一个post的异步请求接口,并返回了文件(此处后端逻辑应该是接收到查询条件,去数 ...

  3. @async 没有异步_扒一扒VueCLI3.0中Axios异步请求同步化

    前台经常会遇到请求同步和异步的问题,今天咱们来聊一聊vue中同步请求和异步请求那些事儿. 说到接口的请求同步和异步问题,最早接触Ajax中就存在,Ajax传递的参数有一个async,默认情况下是fal ...

  4. vue-d2admin-axios异步请求登录,先对比一下Jquery ajax, Axios, Fetch区别

    先说一下对比吧 Jquery ajax, Axios, Fetch区别之我见 引言 前端技术真是一个发展飞快的领域,我三年前入职的时候只有原生XHR和Jquery ajax,我们还曾被JQuery 1 ...

  5. axios异步请求数据的简单使用

    使用Mock模拟好后端数据之后(Mock模拟数据的使用参考:https://segmentfault.com/a/11...),就需要尝试请求加载数据了.数据请求选择了axios,现在都推荐使用axi ...

  6. [vue] 如果将axios异步请求同步化处理?

    [vue] 如果将axios异步请求同步化处理? // 统一处理axios请求async getHistoryData (data) {try {let res = await axios.get(' ...

  7. Js 异步请求按顺序调用解决方案(真实工作场景,axios

    查看控制台打印结果 这样看起来貌似没什么问题,也按顺序输出了.当然,这是理想情况,是因为两个接口都响应的很快,几乎一调用就能返回,所以给我们一种感觉就是按顺序输出了.但是试想一下,如果第一个接口调用的 ...

  8. axios同步和异步请求数据

    axios默认是异步请求数据的,如果需要同步获取数据的话,需要进行设置. 下面的代码默认异步请求数据: <template><div><el-tabs @tab-clic ...

  9. 异步请求-XMLHttpRequest、ajax、axios原理浅析

    异步请求-XMLHttpRequest.ajax.axios原理浅析 XMLHTTPRequest 参考 readyState responseType XMLHttpRequest Level 1 ...

最新文章

  1. C# 简单软件有效期注册的实现【原】
  2. shell第一天,添加普通帐号.
  3. python数据类型-Python语言基本数据类型
  4. myeclipse设置注释格式
  5. Storm累计求和Demo并且在集群上运行
  6. 第十二届蓝桥杯A组省赛试题 I: 双向排序(Java)
  7. gitlab windows安装_【Thrift】Windows编译Thrift源码及其依赖库
  8. [UE4]UMG、HUI、Slate之间的区别
  9. 【转载】徐国洪:好耶向移动广告技术产品转型
  10. DFS Codeforces Round #290 (Div. 2) B. Fox And Two Dots
  11. poj 1270 Following Orders
  12. 21天Jmeter打卡Day19 mysql数据库提取参数化
  13. Install Java on Ubuntu server
  14. loj10157. 「一本通 5.2 例 5」皇宫看守
  15. 微信代扣踩坑日记(微信自动续费)
  16. 京东-黑客马拉松大赛复盘
  17. avr单片机c语言计算log,AVR单片机定时器初值计算公式与方法 - 单片机定时器初值计算公式(51单片机和AVR单片机的初值计算三种方法)...
  18. python 存根_如何用Python编写类方法的存根
  19. 劳务派遣人员是否有加班费
  20. 内部存储器——①静态存储器

热门文章

  1. mac上可以直接查看exif信息
  2. 物联网国赛LORA模块开发基础教程(通用库)—定时器
  3. OneNote显示无法访问OneDrive中的笔记
  4. matlab二维相关随机变量样本点,生成包含N=100个二维样本的数据集
  5. LRM-00109问题的处理,生成pfile文件启动数据库
  6. (2012.01.12-2012.04.01)八十二天的学习小记
  7. 「java工程师」常见面试题及其答案(持续更新)
  8. 高德地图android api定位失败,android 定位没有问题,iOS定位失败获取不到位置信息...
  9. 2023最新仿蓝奏云合集下载页面系统源码 带后台版本
  10. html设置樱花飘落效果,jQuery实现web页面樱花坠落的特效