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 相关文章推荐
JS控制阿拉伯数字转为中文大写示例代码
Sep 04 Javascript
常用js字符串判断方法整理
Oct 18 Javascript
用js来获取上传的文件名纯粹是为了美化而用
Oct 23 Javascript
Javascript获取统一管理的提示语(message)
Feb 03 Javascript
Angular2  NgModule 模块详解
Oct 19 Javascript
详解基于node的前端项目编译时内存溢出问题
Aug 01 Javascript
js 开发之autocomplete=&quot;off&quot;在chrom中失效的解决办法
Sep 28 Javascript
vue中node_modules中第三方模块的修改使用详解
May 31 Javascript
vue使用video.js进行视频播放功能
Jul 18 Javascript
vuex(vue状态管理)的特殊应用案例分享
Mar 03 Javascript
JavaScript实现字符串与HTML格式相互转换
Mar 17 Javascript
如何利用javascript接收json信息并进行处理
Aug 06 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错误日志 display_errors与log_errors的区别
2012/10/09 PHP
探讨:如何编写PHP扩展
2013/06/13 PHP
浅析PHP程序防止ddos,dns,集群服务器攻击的解决办法
2013/06/18 PHP
tp5实现微信小程序多图片上传到服务器功能
2018/07/16 PHP
CSS中简写属性要注意TRouBLe的顺序问题(避免踩坑)
2021/03/09 HTML / CSS
基于jquery的滚动鼠标放大缩小图片效果
2011/10/27 Javascript
js replace替换所有匹配的字符串
2014/02/13 Javascript
JavaScript+CSS实现仿天猫侧边网页菜单效果
2015/08/25 Javascript
JavaScript实现跑马灯抽奖活动实例代码解析与优化(二)
2016/02/16 Javascript
JavaScript实现设计模式中的单例模式的一些技巧总结
2016/05/17 Javascript
jQuery实现base64前台加密解密功能详解
2017/08/29 jQuery
React Native 通告消息竖向轮播组件的封装
2020/08/25 Javascript
vue2.0 如何把子组件的数据传给父组件(推荐)
2018/01/15 Javascript
nodejs 十六进制字符串型数据与btye型数据相互转换
2018/07/30 NodeJs
2019年度web前端面试题总结(主要为Vue面试题)
2020/01/12 Javascript
详解vue beforeEach 死循环问题解决方法
2020/02/25 Javascript
封装 axios+promise通用请求函数操作
2020/08/11 Javascript
JavaScript实现点击出现子菜单效果
2021/02/08 Javascript
Python网页解析利器BeautifulSoup安装使用介绍
2015/03/17 Python
Python中的asyncio代码详解
2019/06/10 Python
Python获取命令实时输出-原样彩色输出并返回输出结果的示例
2019/07/11 Python
对Python中一维向量和一维向量转置相乘的方法详解
2019/08/26 Python
python实现画循环圆
2019/11/23 Python
使用Tensorboard工具查看Loss损失率
2020/02/15 Python
python matlab库简单用法讲解
2020/12/31 Python
lookfantastic荷兰:在线购买奢华护肤、护发和化妆品
2018/11/27 全球购物
美国购买体育、音乐会和剧院门票网站:SelectATicket
2019/09/08 全球购物
Java Servlet API中forward() 与redirect()的区别
2014/04/20 面试题
开展党的群众路线教育实践活动领导班子对照检查材料
2014/09/25 职场文书
个人授权委托书范本格式
2014/10/12 职场文书
出国留学自荐信模板
2015/03/06 职场文书
2020年元旦晚会策划书模板
2019/12/30 职场文书
python如何正确使用yield
2021/05/21 Python
python爬取网页版QQ空间,生成各类图表
2021/06/02 Python
Springboot集成阿里云OSS上传文件系统教程
2021/06/28 Java/Android
vue实现移动端div拖动效果
2022/03/03 Vue.js