Vue.js Ajax(vue-resource)

devtools/2025/1/14 14:08:14/

Vue 要实现异步加载需要使用到 vue-resource 库。

Vue.js 2.0 版本推荐使用 axios 来完成 ajax 请求。

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

Get 请求

以下是一个简单的 Get 请求实例,请求地址是一个简单的 txt 文本:

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>Vue 测试实例</title>
<script src="https://cdn.staticfile.net/vue/2.4.2/vue.min.js"></script>
<script src="https://cdn.staticfile.net/vue-resource/1.5.1/vue-resource.min.js"></script>
</head>
<body>
<div id="box"><input type="button" @click="get()" value="点我异步获取数据(Get)">
</div>
<script type = "text/javascript">
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('请求失败处理');});}}
});
}
</script>
</body>
</html>

如果需要传递数据,可以使用 this.$http.get('get.php',{params : jsonData}) 格式,第二个参数 jsonData 就是传到后端的数据。

this.$http.get('get.php',{params : {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 选项。

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>Vue 测试实例</title>
<script src="https://cdn.staticfile.net/vue/2.4.2/vue.min.js"></script>
<script src="https://cdn.staticfile.net/vue-resource/1.5.1/vue-resource.min.js"></script>
</head>
<body>
<div id="box"><input type="button" @click="post()" value="点我----智能安全。无处不在。">
</div>
<script type = "text/javascript">
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:"BlackBerry",url:"https://www.blackberry.com/cn/zh"},{emulateJSON:true}).then(function(res){document.write(res.body);    },function(res){console.log(res.status);});}}});
}
</script>
</body>
</html>

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对象使用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);

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请求的目标URL
bodyObject, FormData, string作为请求体发送的数据
headersObject作为请求头部发送的头部对象
paramsObject作为URL参数的参数对象
methodstringHTTP方法 (例如GET,POST,...)
timeoutnumber请求超时(单位:毫秒) (0表示永不超时)
beforefunction(request)在请求发送之前修改请求的回调函数
progressfunction(event)用于处理上传进度的回调函数 ProgressEvent
credentialsboolean是否需要出示用于跨站点请求的凭据
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 之间的数值时该值为 true
statusnumberHTTP 响应码
statusTextstringHTTP 响应状态
方法类型描述
text()约定值以字符串方式返回响应体
json()约定值以格式化后的 json 对象方式返回响应体
blob()约定值以二进制 Blob 对象方式返回响应体

http://www.ppmy.cn/devtools/150425.html

相关文章

Windows 蓝牙驱动开发-简介

蓝牙(英语&#xff1a;Bluetooth)是一种无线通信技术标准&#xff0c;用来让固定与移动设备&#xff0c;在短距离间交换资料&#xff0c;以形成个人局域网(PAN)。其使用短波特高频(UHF)无线电波&#xff0c;经由2.4至2.485 GHz的ISM频段来进行通信。1994年由电信商爱立信(Erics…

迅为RK3568开发板篇OpenHarmony配置HDF驱动控制LED-新增 topeet子系统

在 Openharmony 源码根目录下新建 topeet 文件夹及其文件夹下的文件。目录如下所示&#xff1a; 接下来依次解释一下每个文件的作用。 bundle.json&#xff1a; demos&#xff1a;组件目录 hdf_led&#xff1a;子组件目录 app&#xff1a;led 应用层目录 ├── BUILD.gn&#…

从字符串使用看Golang和Rust对内存使用的区别

从字符串使用看Golang和Rust对内存使用的区别 ​ 今天从Rust偶然回到Golang的世界&#xff0c;怎么写代码怎么别扭&#xff0c;总是忍不住在句子结尾加个分号…看到golang的字符串使用起来特别爽可以到处复制疯狂乱用&#xff0c;有一种从部队宿舍豆腐块被子的生活回归到居家肥…

监控易钢铁行业:IT 设备、动环设施全方位一体化监控

在当今数字化浪潮汹涌澎湃的时代&#xff0c;各行业对信息技术的依赖程度日益加深&#xff0c;钢铁行业亦不例外。作为钢铁行业的中流砥柱&#xff0c;某钢铁公司在贸易、信息科技、循环经济和物流等多元业务领域开疆拓土&#xff0c;取得了斐然佳绩。 然而&#xff0c;随着业务…

【华为OD-E卷 - 篮球比赛 100分(python、java、c++、js、c)】

【华为OD-E卷 - 篮球比赛 100分&#xff08;python、java、c、js、c&#xff09;】 题目 篮球(5V5)比赛中&#xff0c;每个球员拥有一个战斗力&#xff0c;每个队伍的所有球员战斗力之和为该队伍的总体战斗力。 现有10个球员准备分为两队进行训练赛&#xff0c;教练希望2个队…

【PPTist】插入形状、插入图片、插入图表

一、插入形状 插入形状有两种情况&#xff0c;一种是插入固定的形状&#xff0c; 一种是插入自定义的形状。 插入固定的形状时&#xff0c;跟上一篇文章 绘制文本框 是一样一样的&#xff0c;都是调用的 mainStore.setCreatingElement() 方法&#xff0c;只不多传的类型不一…

PHP语言的学习路线

PHP语言的学习路线 PHP&#xff08;Hypertext Preprocessor&#xff09;是一种广泛使用的开源服务器端脚本语言&#xff0c;尤其适用于Web开发。由于其易学易用、功能强大&#xff0c;PHP成为了许多动态网站和Web应用程序开发的首选语言。随着Web3.0和云计算的兴起&#xff0c…

【数据仓库】— 5分钟浅谈数据仓库(适合新手)从理论到实践

大家好&#xff0c;我是摇光~ 对于刚进入大数据领域的萌新&#xff0c;且想要在数据分析岗、数据运维岗、数据工程师这些岗位立足&#xff0c;了解数据仓库是必要的&#xff0c;接下来我尽量用通俗易懂的语言让大家了解到数据仓库。 在当今大数据盛行的时代&#xff0c;数据仓…