Vue笔记6.2 : Ajax (基于vue-resource)

Vue可以使用vue-resource实现ajax的操作 , 需要额外库
Vue.js 2.0 版本推荐使用 axios 来完成 ajax 请求

引用库 :

<script src="https://cdn.staticfile.org/vue-resource/1.5.1/vue-resource.min.js"></script>

 

示例

 get示例

<script>
window.onload = function(){
    var vm = new Vue({
        el:'#box',
        data:{
            msg:'Hello World!',
        },
        methods:{
            get:function(){
                //发送get请求
                this.$http.get('/try/ajax/ajax_info.txt').then(function(res){
                    document.write(res.body);    
                },function(){
                    console.log('请求失败处理');
                });
                /*
                 *  加参数的方式 : 
                 *    this.$http.get('get.php',{params : {a:1,b:2}}).then(function(res){
                 *        document.write(res.body);    
                 *    },function(res){
                 *        console.log(res.status);
                 *    });
                 */
            }
        }
    });
}
</script>

 

post示例

post 发送数据到后端,需要第三个参数 {emulateJSON:true
emulateJSON 的作用: 如果Web服务器无法处理编码为 application/json 的请求,你可以启用 emulateJSON 选项
演示 : https://www.runoob.com/try/try.php?filename=vue2-ajax2

<script>
window.onload = function(){
    var vm = new Vue({
        el:'#box',
        data:{
            msg:'Hello World!',
        },
        methods:{
            post:function(){
                //发送 post 请求
                this.$http.post('/try/ajax/demo_test_post.php',{name:"菜鸟教程",url:"http://www.runoob.com"},{emulateJSON:true}).then(function(res){
                    document.write(res.body);    
                },function(res){
                    console.log(res.status);
                });
            }
        }
    });
}
</script>

 

语法 & API :

<script>
// 基于全局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);
</script>

 

vue-resource 提供了 7 种请求 API(REST 风格): 

get(url, [options])
head(url, [options])
delete(url, [options])
jsonp(url, [options])              //就这一个不是标准的 HTTP 方法
post(url, [body], [options])
put(url, [body], [options])
patch(url, [body], [options])

 

除了 jsonp 以外,另外 6 种的 API 名称是标准的 HTTP 方法。
options 参数说明:

参数 

类型 描述
url string 请求的目标URL
body Object, FormData, string 作为请求体发送的数据
headers Object 作为请求头部发送的头部对象
params Object 作为URL参数的参数对象
method string HTTP方法 (例如GET,POST,...)
timeout number 请求超时(单位:毫秒) (0表示永不超时)
before function(request) 在请求发送之前修改请求的回调函数
progress function(event) 用于处理上传进度的回调函数 ProgressEvent
credentials boolean 是否需要出示用于跨站点请求的凭据
emulateHTTP boolean 是否需要通过设置X-HTTP-Method-Override头部并且以传统POST方式发送PUT,PATCH和DELETE请求。
emulateJSON boolean 设置请求体的类型为application/x-www-form-urlencoded
     

 

 

 

通过如下属性和方法处理一个请求获取到的响应对象:

属性

类型 描述
url string 响应的 URL 源
body Object, Blob, string 响应体数据
headers Header 请求头部对象
ok boolean 当 HTTP 响应码为 200 到 299 之间的数值时该值为 true
status number HTTP 响应码
statusText string HTTP 响应状态
方法 类型 描述
text() 约定值 以字符串方式返回响应体
json() 约定值 以格式化后的 json 对象方式返回响应体
blob() 约定值 以二进制 Blob 对象方式返回响应体



 

上一篇:codeforces B. Ciel and Flowers 解题报告


下一篇:API-6_3 WebAPI跨域与AJAX请求