vue请求数据的三种方式


Posted in Javascript onMarch 04, 2020

请求数据的方式:

  • 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

<template>
  <div id="info">
    <button @click="getData">获取数据</button>
    <ul>
      <li v-for="(item,index) in list" v-bind:key="index">
        {{item.title}}
      </li>
    </ul>
  </div>
</template>

<script>
  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();
    }
  }
</script>

如果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请求数据

介绍:这是一个第三方的插件 github地址:https://github.com/axios/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填写自己想要的地址

vue请求数据的三种方式

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

vue请求数据的三种方式

关于多个并发请求:

vue请求数据的三种方式

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

三,关于fetch-jsonp

github地址:https://github.com/camsong/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 请求数据内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Javascript 相关文章推荐
利用404错误页面实现UrlRewrite的实现代码
Aug 20 Javascript
js parseInt(&quot;08&quot;)未指定进位制问题
Jun 19 Javascript
jquery.boxy插件的iframe扩展代码
Jul 02 Javascript
Jquery chosen动态设置值实例介绍
Aug 08 Javascript
jQuery选择器简明总结(含用法实例,一目了然)
Apr 25 Javascript
探寻JavaScript中this指针指向
Apr 23 Javascript
概述一个页面从输入URL到页面加载完的过程
Dec 16 Javascript
彻底学会Angular.js中的transclusion
Mar 12 Javascript
用vue和node写的简易购物车实现
Apr 25 Javascript
BootStrap Table复选框默认选中功能的实现代码(从数据库获取到对应的状态进行判断是否为选中状态)
Jul 11 Javascript
Jquery中.bind()、.live()、.delegate()和.on()之间的区别详解
Aug 01 jQuery
详解vue中axios请求的封装
Apr 08 Javascript
使用Vue 自定义文件选择器组件的实例代码
Mar 04 #Javascript
JS中==、===你分清楚了吗
Mar 04 #Javascript
js数组相减简单示例【删除a数组所有与b数组相同元素】
Mar 04 #Javascript
通过实例了解Javascript柯里化流程
Mar 03 #Javascript
微信小程序getLocation 需要在app.json中声明permission字段
Mar 03 #Javascript
Javascript作用域和作用域链原理解析
Mar 03 #Javascript
JS数组方法reduce的用法实例分析
Mar 03 #Javascript
You might like
简单介绍下 PHP5 中引入的 MYSQLI的用途
2007/03/19 PHP
PHP 远程文件管理,可以给表格排序,遍历目录,时间排序
2009/08/07 PHP
golang与php实现计算两个经纬度之间距离的方法
2016/07/22 PHP
jquery select选中的一个小问题
2009/10/11 Javascript
JS 控制非法字符的输入代码
2009/12/04 Javascript
jQuery下拉友情链接美化效果代码分享
2015/08/26 Javascript
JS中关于事件处理函数名后面是否带括号的问题
2016/11/16 Javascript
JavaScript 中对象的深拷贝
2016/12/04 Javascript
jQuery Ajax请求后台数据并在前台接收
2016/12/10 Javascript
vue中v-for加载本地静态图片方法
2018/03/03 Javascript
Vue中的scoped实现原理及穿透方法
2018/05/15 Javascript
JS实现前端动态分页码代码实例
2020/06/02 Javascript
[01:25]2015国际邀请赛最佳短片奖——斧王《拆塔英雄:天赋异禀》
2015/09/22 DOTA
Python图像处理之识别图像中的文字(实例讲解)
2018/05/10 Python
python统计字母、空格、数字等字符个数的实例
2018/06/29 Python
处理python中多线程与多进程中的数据共享问题
2019/07/28 Python
在django模板中实现超链接配置
2019/08/21 Python
Python3 使用map()批量的转换数据类型,如str转float的实现
2019/11/29 Python
详解Python中namedtuple的使用
2020/04/27 Python
Python中Yield的基本用法
2020/10/18 Python
资生堂美国官网:Shiseido美国
2016/09/02 全球购物
墨尔本最受欢迎的复古风格品牌:Princess Highway
2018/12/21 全球购物
Net Remoting把服务器端激活两种模式
2014/01/22 面试题
简历中自我评价分享
2013/10/09 职场文书
毕业生文员求职信
2013/11/03 职场文书
西北政法大学自主招生自荐信
2014/01/29 职场文书
生日宴会主持词
2014/03/20 职场文书
教师党员个人剖析材料
2014/09/29 职场文书
公司副总经理岗位职责
2015/04/08 职场文书
2016公司年会通知范文
2015/04/25 职场文书
2015年支教教师工作总结
2015/07/22 职场文书
nginx实现发布静态资源的方法
2021/03/31 Servers
有趣的二维码:使用MyQR和qrcode来制作二维码
2021/05/10 Python
Python数据分析之pandas读取数据
2021/06/02 Python
springboot如何初始化执行sql语句
2021/06/22 Java/Android
Nginx速查手册及常见问题
2022/04/07 Servers