vue三种ajax请求方式,vue请求数据的三种方式

请求数据的方式:

vue-resource 官方提供的 vue的一个插件

axios

fetch-jsonp

一,vue-resource请求数据

介绍:vue-resource请求数据方式是官方提供的一个插件

使用步骤:

1、安装vue-resource模块

cnpm install vue-resource --save

加--save是为了在package.json中引用,表示在生产环境中使用。因为我们在日常开发中,如果我们要打包代码给其他人或者上传到github,又或者要发布代码时,package.json就是安装所需要的包。如果只在开发环境中使用,则只需要--save-dev,有一些只在开发环境中用,有一些要在生产环境中用。

2、在 main.js 引入 vue-resource

import VueResource from 'vue-resource';

Vue.use(VueResource);

3、在组件里面直接使用

this.$http.get(地址).then(function(){

})

注意:this.$http.get()等等的各种http请求都是继承promise的。promise是异步的请求;其次,.then箭头函数里的this代表的是上下文。根据箭头函数this的定义,只在函数定义时就已经赋值可知,this,指代的是定义函数的对象,在vue中对象就是methods当前页面。所以this指导的是data里面的数据。如果想要获取包裹函数外函数的数据,即闭包的概念。实现方法就是在外层函数加一个var that =  this;将外层的this先储存到that中。

实例:

Info.vue

获取数据

  • {{item.title}}

export default {

name: "Info",

data() {

return {

list: []

}

},

methods: {

getData: function () {

let api = 'http://www.phonegap100.com/appapi.php?a=getPortalList&catid=20&page=1';

//此处推荐使用箭头函数。

this.$http.get(api).then((res)=>{

this.list = res.body.result;

}, (err)=>{

console.log(err);

});

}

},

mounted() {

this.getData();

}

}

如果getData()中不适用箭头函数,就需要注意this问题。

getData: function () {

let api = 'http://www.phonegap100.com/appapi.php?a=getPortalList&catid=20&page=1';

const _this = this;

this.$http.get(api).then(function (res) {

_this.list = res.body.result;

}, function (err) {

console.log(err);

});

}

二,axios请求数据

axios 与 fetch-jsonp 同为第三方插件

1、安装

cnpm install axios --save

直接调用。和vue-resource的区别是:aixos是每在一个页面用一次就要在该页面调用一次。vue-resource是绑定了全局的了。

2、哪里用哪里引入axios

Axios.get(api).then((response)=>{

this.list=response.data.result;

}).catch((error)=>{

console.log(error);

})

关于axios的跨域请求

在config->index.js->proxyTable配置如下:target填写自己想要的地址

9d6deb3726e1c6e257504d2a2573b596.png

如下配置,url为地址后面所带的参数,配置好后,现在npm run dev 运行就行。

c4a73e6183e54bbef53685043d060378.png

关于多个并发请求:

c827d23fcf97f01d168e10283d496ea2.png

上面这个是同一地址的跨域,如果要拿不同地址的跨域,只需要更改config->index.js->proxyTable的配置,增加地址块就行。

三,关于fetch-jsonp

1、安装

cnpm install fetch-jsonp --save

2、哪里用哪里引入fetch-jsonp

fetchJsonp('/users.jsonp')

.then(function(response) {

return response.json()

}).then(function(json) {

console.log('parsed json', json)

}).catch(function(ex) {

console.log('parsing failed', ex)

})

到此这篇关于vue请求数据的三种方式的文章就介绍到这了,更多相关vue 请求数据内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

时间: 2020-03-01

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值