vue-resource 实现 get, post, jsonp请求
一、解释
1、安装与引用
NPM: npm install vue-resource --save-dev
除了 vue-resource 之外,还可以使用 `axios` 的第三方包实现实现数据的请求
/*引入Vue框架*/ import Vue from 'vue' /*引入资源请求插件*/ import VueResource from 'vue-resource' /*使用VueResource插件*/ Vue.use(VueResource)
2、使用语法
// 基于全局Vue对象使用http Vue.http.get('/someUrl', [options]).then(successCallback, errorCallback); Vue.http.post('/someUrl', [body:传入服务器的参数], [options:提交格式类型]).then(successCallback, errorCallback); // 在一个Vue实例内使用$http this.$http.get('/someUrl', [options]).then(successCallback, errorCallback); this.$http.post('/someUrl', [body], [options]).then(successCallback, errorCallback);
3、options对象
二、实例
<body> <div id="app"> <input type="button" value="get请求" @click="getInfo"> <input type="button" value="post请求" @click="postInfo"> <input type="button" value="jsonp请求" @click="jsonpInfo"> </div> <script> // 创建 Vue 实例,得到 ViewModel var vm = new Vue({ el: '#app', data: {}, methods: { getInfo() { // 发起get请求 // 当发起get请求之后, 通过 .then 来设置成功的回调函数 this.$http.get('http://vue.xxx.io/api/getlunbo').then(function (result) { // 通过 result.body 拿到服务器返回的成功的数据 console.log(result.body) }) }, postInfo() { // 发起 post 请求 application/x-wwww-form-urlencoded // 手动发起的 Post 请求,默认没有表单格式,所以,有的服务器处理不了 // 通过 post 方法的第三个参数, { emulateJSON: true } 设置 提交的内容类型 为 普通表单数据格式 this.$http.post('http://vue.xxx.io/api/post', {}, { emulateJSON: true }).then(result => { console.log(result.body) }) }, jsonpInfo() { // 发起JSONP 请求 this.$http.jsonp('http://vue.xxx.io/api/jsonp').then(result => { console.log(result.body) }) } } }); </script> </body>