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 相关文章推荐
Mozilla中显示textarea中选择的文字
Sep 07 Javascript
JS 继承实例分析
Nov 04 Javascript
js跟随滚动条滚动浮动代码
Dec 31 Javascript
js 图片等比例缩放代码
May 13 Javascript
js中日期的加减法
May 06 Javascript
谈谈Jquery ajax中success和complete有哪些不同点
Nov 20 Javascript
BOM之navigator对象和用户代理检测
Feb 10 Javascript
vue-router路由简单案例介绍
Feb 21 Javascript
Vuex中mutations与actions的区别详解
Mar 01 Javascript
JS中获取 DOM 元素的绝对位置实例详解
Apr 23 Javascript
vue在自定义组件中使用v-model进行数据绑定的方法
Mar 25 Javascript
element-ui中Table表格省市区合并单元格的方法实现
Aug 07 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 常见郁闷问题答解
2006/11/25 PHP
PHP 字符串分割和比较
2009/10/06 PHP
Php 构造函数construct的前下划线是双的_
2009/12/08 PHP
PHP5中实现多态的两种方法实例分享
2014/04/21 PHP
php+ajax实现无刷新分页
2015/11/18 PHP
使用PHP开发留言板功能
2019/11/19 PHP
Prototype RegExp对象 学习
2009/07/19 Javascript
jquery插件如何使用 jQuery操作Cookie插件使用介绍
2012/12/15 Javascript
jQuery:节点(插入,复制,替换,删除)操作
2013/03/04 Javascript
js中style.display=&quot;&quot;无效的解决方法
2014/10/30 Javascript
jQuery实现简单滚动动画效果
2016/04/07 Javascript
JavaScript实现打开链接页面的方式汇总
2016/06/02 Javascript
jquery输入数字随机抽奖特效的简单实现代码
2016/06/10 Javascript
jquery延迟对象解析
2016/10/26 Javascript
原生javascript实现图片放大镜效果
2017/01/18 Javascript
基于Nodejs利用socket.io实现多人聊天室
2017/02/22 NodeJs
微信小程序冒泡事件及其阻止方法实例分析
2018/12/06 Javascript
Vue.extend实现挂载到实例上的方法
2019/05/01 Javascript
基于JavaScript获取url参数2种方法
2020/04/17 Javascript
JS+CSS实现过渡特效
2021/01/02 Javascript
关于better-scroll插件的无法滑动bug(2021通过插件解决)
2021/03/01 Javascript
[03:57]《不朽》——2015DOTA2国际邀请赛—中国军团出征主题曲MV
2015/07/15 DOTA
[05:20]2018DOTA2亚洲邀请赛主赛事第三日战况回顾 LGD率先挺进胜者组决赛
2018/04/06 DOTA
python二叉树的实现实例
2013/11/21 Python
本地文件上传到七牛云服务器示例(七牛云存储)
2014/01/11 Python
简述Python中的进程、线程、协程
2016/03/18 Python
Python批量查询域名是否被注册过
2017/06/21 Python
python数据抓取分析的示例代码(python + mongodb)
2017/12/25 Python
pandas实现to_sql将DataFrame保存到数据库中
2019/07/03 Python
python实现桌面气泡提示功能
2019/07/29 Python
Python集成开发工具Pycharm的安装和使用详解
2020/03/18 Python
详解pycharm的python包opencv(cv2)无代码提示问题的解决
2021/01/29 Python
意大利中国电子产品购物网站:Geekmall.com
2019/09/30 全球购物
竞选大学学委演讲稿
2014/09/13 职场文书
同意报考证明
2015/06/17 职场文书
2019最新企业员工考勤管理制度(通用版)!
2019/07/02 职场文书