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 相关文章推荐
浅谈JavaScript字符串与数组
Jun 03 Javascript
jquery append 动态添加的元素事件on 不起作用的解决方案
Jul 30 Javascript
javascript实现随机读取数组的方法
Aug 03 Javascript
深入解析JavaScript框架Backbone.js中的事件机制
Feb 14 Javascript
JavaScript事件学习小结(五)js中事件类型之鼠标事件
Jun 09 Javascript
AngularJS 依赖注入详解及示例代码
Aug 17 Javascript
关于Jquery中的bind(),on()绑定事件方式总结
Oct 26 Javascript
jQuery Plupload上传插件的使用
Apr 19 jQuery
JS中的数组转变成JSON格式字符串的方法
May 09 Javascript
AngularJs ng-change事件/指令的用法小结
Nov 01 Javascript
解决Vue项目打包后打开index.html页面显示空白以及图片路径错误的问题
Oct 25 Javascript
js如何验证密码强度
Mar 18 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
php discuz 主题表和回帖表的设计
2009/03/13 PHP
解析thinkphp中的M()与D()方法的区别
2013/06/22 PHP
CI(CodeIgniter)框架配置
2014/06/10 PHP
php制作文本式留言板
2015/03/18 PHP
php构造函数与析构函数
2016/04/23 PHP
微信支付扫码支付php版
2016/07/22 PHP
TP5框架请求响应参数实例分析
2019/10/17 PHP
ie8下修改input的type属性报错的解决方法
2014/09/16 Javascript
jQuery选择器querySelector的使用指南
2015/01/23 Javascript
nodejs实现获取当前url地址及url各种参数值
2015/06/25 NodeJs
JS中生成随机数的用法及相关函数
2016/01/09 Javascript
修改jquery中dialog的title属性方法(推荐)
2016/08/26 Javascript
学习掌握JavaScript中this的使用技巧
2016/08/29 Javascript
js获取隐藏元素的宽高
2017/02/24 Javascript
微信小程序显示下拉列表功能【附源码下载】
2017/12/12 Javascript
详解swipe使用及竖屏页面滚动方法
2018/06/28 Javascript
JS实现数组去重,显示重复元素及个数的方法示例
2019/01/21 Javascript
Express结合Webpack的全栈自动刷新
2019/05/23 Javascript
JavaScript 防抖和节流遇见的奇怪问题及解决
2020/11/20 Javascript
python 系统调用的实例详解
2017/07/11 Python
使用python对文件中的单词进行提取的方法示例
2018/12/21 Python
将pip源更换到国内镜像的详细步骤
2019/04/07 Python
python模拟菜刀反弹shell绕过限制【推荐】
2019/06/25 Python
python多线程并发实例及其优化
2019/06/27 Python
Python动态语言与鸭子类型详解
2019/07/01 Python
python 实现单通道转3通道
2019/12/03 Python
北体毕业生求职信
2014/02/28 职场文书
《沉香救母》教学反思
2014/04/19 职场文书
关于责任的演讲稿
2014/05/20 职场文书
行政求职信
2014/07/04 职场文书
销售团队获奖感言
2014/08/14 职场文书
高职教师先进事迹材料
2014/08/24 职场文书
大学生考试作弊被抓检讨书
2014/12/27 职场文书
元宵节寄语大全
2015/02/27 职场文书
灵魂歌王观后感
2015/06/17 职场文书
MySQL系列之五 视图、存储函数、存储过程、触发器
2021/07/02 MySQL