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 Select操作大集合
May 26 Javascript
学习ExtJS Panel常用方法
Oct 07 Javascript
目前流行的JavaScript库的介绍及对比
Sep 29 Javascript
不同Jquery版本引发的问题解决
Oct 14 Javascript
jquery toolbar与网页浮动工具条具体实现代码
Jan 12 Javascript
js字符串完全替换函数分享
Dec 03 Javascript
js实现超酷的照片墙展示效果图附源码下载
Oct 08 Javascript
表单验证正则表达式实例代码详解
Nov 09 Javascript
详解JS数组Reduce()方法详解及高级技巧
Aug 18 Javascript
JS实现的简单表单验证功能示例
Oct 13 Javascript
详解微信小程序实现仿微信聊天界面(各种细节处理)
Feb 17 Javascript
Vue中img的src是动态渲染时不显示的解决
Nov 14 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/10/09 PHP
php下实现伪 url 的超简单方法[转]
2007/09/24 PHP
web站点获取用户IP的安全方法 HTTP_X_FORWARDED_FOR检验
2013/06/01 PHP
js中的异常处理try...catch使用介绍
2013/09/21 Javascript
基于jQuery实现复选框的全选 全不选 反选功能
2014/11/24 Javascript
jquery实现相册一下滑动两次的方法
2015/02/09 Javascript
JS/Jquery判断对象为空的方法
2015/06/11 Javascript
jquery实现简易的移动端验证表单
2015/11/08 Javascript
简单了解JavaScript操作XPath的一些基本方法
2016/06/03 Javascript
使用vue.js2.0 + ElementUI开发后台管理系统详细教程(一)
2017/01/21 Javascript
Array数组对象中的forEach、map、filter及reduce详析
2018/08/02 Javascript
Koa日志中间件封装开发详解
2019/03/09 Javascript
VueJs里利用CryptoJs实现加密及解密的方法示例
2019/04/29 Javascript
详解mpvue中使用vant时需要注意的onChange事件的坑
2019/05/16 Javascript
基于JS实现父组件的请求服务过程解析
2019/10/14 Javascript
浅谈Vue为什么不能检测数组变动
2019/10/14 Javascript
Vue+ElementUI table实现表格分页
2019/12/14 Javascript
python高手之路python处理excel文件(方法汇总)
2016/01/07 Python
python魔法方法-属性转换和类的表示详解
2016/07/22 Python
Python内建函数之raw_input()与input()代码解析
2017/10/26 Python
Python解析并读取PDF文件内容的方法
2018/05/08 Python
浅谈PYTHON 关于文件的操作
2019/03/19 Python
python将字符串转变成dict格式的实现
2019/11/18 Python
Pytorch实现LSTM和GRU示例
2020/01/14 Python
python实现的分层随机抽样案例
2020/02/25 Python
pyspark对Mysql数据库进行读写的实现
2020/12/30 Python
为什么group by 和order by会使查询变慢
2014/05/16 面试题
.net C#面试题
2012/08/28 面试题
税务干部鉴定材料
2014/02/11 职场文书
学历公证委托书
2014/04/09 职场文书
公司节能减排方案
2014/05/16 职场文书
社保委托书怎么写
2014/08/02 职场文书
四风个人对照检查材料思想汇报(办公室通用版)
2014/10/07 职场文书
2014年保卫科工作总结
2014/12/05 职场文书
研究生个人学年总结
2015/02/14 职场文书
springboot + mongodb 通过经纬度坐标匹配平面区域的方法
2021/11/01 MongoDB