- ·上一篇文章:Vue.js 混入
- ·下一篇文章:Vue.js 响应接口
Vue.js Ajax(vue-resource)
Vue.js Ajax(vue-resource)Vue 要实现异步加载需要使用到 vue-resource 库。<script src="https:
//cdn.staticfile.org/vue-resource/1.5.1/vue-resource.min.js"></script>Get 请求以下是一个简单的 Get 请求实例,请求地址是一个简单的 txt 文本:实例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',jsonData) 格式,第二个参数 jsonData 就是传到后端的数据。this.$http.get('get.php',{a:
1,b:
2}).then(function(res){ document.write(res.body); },function(res){ console.log(res.status);});post 请求post 发送数据到后端,需要第三个参数 {emulateJSON:
true}。emulateJSON 的作用: 如果Web服务器无法处理编码为 application/json 的请求,你可以启用 emulateJSON 选项。实例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:
"k88.net",url:
"http:
//www.k88.net"},{emulateJSON:
true}).then(function(res){document.write(res.body);},function(res){console.log(res.status);});}}});}尝试一下 ?demo_test_post.php 代码如下:<?php$name = isset($_POST['name']) ? htmlspecialchars($_POST['name']) :
'';$city = isset($_POST['url']) ? htmlspecialchars($_POST['url']) :
'';echo '网站名:
' . $name;echo "\n";echo 'URL 地址:
' .$city;?>语法 & API你可以使用全局对象方式 Vue.http 或者在一个 Vue 实例的内部使用 this.$http来发起 HTTP 请求。// 基于全局Vue对象使用httpVue.http.get('/someUrl', [options]).then(successCallback, errorCallback);Vue.http.post('/someUrl', [body], [options]).then(successCallback, errorCallback);// 在一个Vue实例内使用$httpthis.$http.get('/someUrl', [options]).then(successCallback, errorCallback);this.$http.post('/someUrl', [body], [options]).then(successCallback, errorCallback);vue-resource 提供了 7 种请求 API(REST 风格):get(url, [options])head(url, [options])delete(url, [options])jsonp(url, [options])post(url, [body], [options])put(url, [body], [options])patch(url, [body], [options])除了 jsonp 以外,另外 6 种的 API 名称是标准的 HTTP 方法。options 参数说明:
参数类型描述urlstring请求的目标URLbodyObject, FormData, string作为请求体发送的数据headersObject作为请求头部发送的头部对象paramsObject作为URL参数的参数对象methodstringHTTP方法 (例如GET,POST,...)timeoutnumber请求超时(单位:毫秒) (0表示永不超时)beforefunction(request)在请求发送之前修改请求的回调函数progressfunction(event)用于处理上传进度的回调函数 ProgressEventcredentialsboolean是否需要出示用于跨站点请求的凭据emulateHTTPboolean是否需要通过设置X-HTTP-Method-Override头部并且以传统POST方式发送PUT,PATCH和DELETE请求。emulateJSONboolean设置请求体的类型为application/x-www-form-urlencoded通过如下属性和方法处理一个请求获取到的响应对象:属性类型描述urlstring响应的URL源bodyObject, Blob, string响应体数据headersHeader请求头部对象okboolean当HTTP响应码为200到299之间的数值时该值为truestatusnumberHTTP响应吗statusTextstringHTTP响应状态方法类型描述text()约定值以字符串方式返回响应体json()约定值以格式化后的json对象方式返回响应体blob()约定值以二进制Blob对象方式返回响应体
//cdn.staticfile.org/vue-resource/1.5.1/vue-resource.min.js"></script>Get 请求以下是一个简单的 Get 请求实例,请求地址是一个简单的 txt 文本:实例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',jsonData) 格式,第二个参数 jsonData 就是传到后端的数据。this.$http.get('get.php',{a:
1,b:
2}).then(function(res){ document.write(res.body); },function(res){ console.log(res.status);});post 请求post 发送数据到后端,需要第三个参数 {emulateJSON:
true}。emulateJSON 的作用: 如果Web服务器无法处理编码为 application/json 的请求,你可以启用 emulateJSON 选项。实例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:
"k88.net",url:
"http:
//www.k88.net"},{emulateJSON:
true}).then(function(res){document.write(res.body);},function(res){console.log(res.status);});}}});}尝试一下 ?demo_test_post.php 代码如下:<?php$name = isset($_POST['name']) ? htmlspecialchars($_POST['name']) :
'';$city = isset($_POST['url']) ? htmlspecialchars($_POST['url']) :
'';echo '网站名:
' . $name;echo "\n";echo 'URL 地址:
' .$city;?>语法 & API你可以使用全局对象方式 Vue.http 或者在一个 Vue 实例的内部使用 this.$http来发起 HTTP 请求。// 基于全局Vue对象使用httpVue.http.get('/someUrl', [options]).then(successCallback, errorCallback);Vue.http.post('/someUrl', [body], [options]).then(successCallback, errorCallback);// 在一个Vue实例内使用$httpthis.$http.get('/someUrl', [options]).then(successCallback, errorCallback);this.$http.post('/someUrl', [body], [options]).then(successCallback, errorCallback);vue-resource 提供了 7 种请求 API(REST 风格):get(url, [options])head(url, [options])delete(url, [options])jsonp(url, [options])post(url, [body], [options])put(url, [body], [options])patch(url, [body], [options])除了 jsonp 以外,另外 6 种的 API 名称是标准的 HTTP 方法。options 参数说明:
参数类型描述urlstring请求的目标URLbodyObject, FormData, string作为请求体发送的数据headersObject作为请求头部发送的头部对象paramsObject作为URL参数的参数对象methodstringHTTP方法 (例如GET,POST,...)timeoutnumber请求超时(单位:毫秒) (0表示永不超时)beforefunction(request)在请求发送之前修改请求的回调函数progressfunction(event)用于处理上传进度的回调函数 ProgressEventcredentialsboolean是否需要出示用于跨站点请求的凭据emulateHTTPboolean是否需要通过设置X-HTTP-Method-Override头部并且以传统POST方式发送PUT,PATCH和DELETE请求。emulateJSONboolean设置请求体的类型为application/x-www-form-urlencoded通过如下属性和方法处理一个请求获取到的响应对象:属性类型描述urlstring响应的URL源bodyObject, Blob, string响应体数据headersHeader请求头部对象okboolean当HTTP响应码为200到299之间的数值时该值为truestatusnumberHTTP响应吗statusTextstringHTTP响应状态方法类型描述text()约定值以字符串方式返回响应体json()约定值以格式化后的json对象方式返回响应体blob()约定值以二进制Blob对象方式返回响应体
Vue.js Ajax(vue-resource)