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 02 Javascript
JQuery切换显示的效果实例代码
Feb 27 Javascript
JS 退出系统并跳转到登录界面的实现代码
Jun 29 Javascript
在JavaScript中操作数组之map()方法的使用
Jun 09 Javascript
Jquery实现弹性滑块滑动选择数值插件
Aug 08 Javascript
微信小程序 前端源码逻辑和工作流详解
Oct 08 Javascript
微信小程序小组件 基于Canvas实现直播点赞气泡效果
May 29 Javascript
Bootstrap + AngularJS 实现简单的数据过滤字符查找功能
Jul 27 Javascript
浅谈微信页面入口文件被缓存解决方案
Sep 29 Javascript
详解基于React.js和Node.js的SSR实现方案
Mar 21 Javascript
解决vue组件销毁之后计时器继续执行的问题
Jul 21 Javascript
js实现类选择器和name属性选择器的示例步骤
Feb 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关闭warning问题的解决方法
2016/05/17 PHP
Javascript模块模式分析
2008/05/16 Javascript
jQuery插件开发全解析
2012/10/10 Javascript
jquery文字上下滚动的实现方法
2013/03/22 Javascript
alert和confirm功能介绍
2014/05/21 Javascript
js实现带关闭按钮始终显示在网页最底部工具条的方法
2015/03/02 Javascript
深入学习JavaScript中的原型prototype
2015/08/13 Javascript
微信小程序 解决swiper不显示图片的方法
2017/01/04 Javascript
javascript编写简易计算器
2017/05/06 Javascript
Angular 4依赖注入学习教程之FactoryProvider配置依赖对象(五)
2017/06/04 Javascript
iview给radio按钮组件加点击事件的实例
2017/09/30 Javascript
利用JS实现scroll自定义滚动效果详解
2017/10/17 Javascript
vue短信验证性能优化如何写入localstorage中
2018/04/25 Javascript
nodejs的路径问题的解决
2018/06/30 NodeJs
layui table表格数据的新增,修改,删除,查询,双击获取行数据方式
2019/11/14 Javascript
Vue filter 过滤当前时间 实现实时更新效果
2019/12/20 Javascript
在Python中操作时间之mktime()方法的使用教程
2015/05/22 Python
python实现m3u8格式转换为mp4视频格式
2018/02/28 Python
Python实现矩阵相乘的三种方法小结
2018/07/26 Python
python3.6利用pyinstall打包py为exe的操作实例
2018/10/31 Python
Django项目使用CircleCI的方法示例
2019/07/14 Python
python程序文件扩展名知识点详解
2020/02/27 Python
python raise的基本使用
2020/09/10 Python
高清屏中使用Canvas绘图出现模糊的问题及解决方法
2019/06/03 HTML / CSS
Otticanet美国:最顶尖的世界名牌眼镜, 能得到打折季的价格
2019/03/10 全球购物
华为慧通面试题
2012/09/11 面试题
Order by的几种用法
2013/06/16 面试题
卫校毕业生自我鉴定
2013/10/31 职场文书
日语专业毕业生求职信
2013/12/04 职场文书
初中物理教学反思
2014/01/14 职场文书
高中生期末评语
2014/01/28 职场文书
致垒球运动员加油稿
2014/02/16 职场文书
校运动会广播稿300字
2014/10/07 职场文书
教你使用VS Code的MySQL扩展管理数据库的方法
2022/01/22 MySQL
浅析Python OpenCV三种滤镜效果
2022/04/11 Python
Java获取字符串编码格式实现思路
2022/09/23 Java/Android