javascript - 从表单提交后的 XMLHttpRequest()
问题描述
我是 Javascript 新手,我可以XMLHttpRequest()
在从表单点击提交后使用,但结果应该与 onclick 事件相同。我有一个名为的函数get
,通过使用XMLHttpRequest()
我可以在 div 中添加一个新对象sample
,如果它是一个按钮,它就可以工作。唯一的区别是我想在提交表单后向 div 添加新对象sample
而不重定向到http://127.0.0.1:5000/get?query=apple
,在这种情况下,表单和函数 get() 应该一起工作。而且我也不想http://127.0.0.1:5000/get?query=apple
在提交表单后在浏览器的 url 字段中看到 。我需要一些帮助,我推动自己尽可能使用纯 js,而不是依赖 jquery。
<div id="sample"></div>
<div onclick="get('apple');">CLICK APPLE</div>
<form action="/get" method="GET">
<input name="query">
<input type="submit">
</form>
<script>
function get(query) {
var xhttp = new XMLHttpRequest();
xhttp.onreadystatechange = function() {
if (this.readyState == 4 && this.status == 200) {
document.getElementById("sample").innerHTML =
this.responseText;
}
};
xhttp.open("GET", "get?query=" + query, true);
xhttp.send();
};
</script>
解决方案
这就是您可以中断提交事件并做任何您想做的事情的方式。
<div id="sample"></div>
<div onclick="get('apple');">CLICK APPLE</div>
<form id="form">
<input name="query">
<input type="submit" value="Submit">
</form>
<script>
document.querySelector('#form').addEventListener('submit', function(e){
e.preventDefault();
var query = e.target.elements['query'].value;
get(query);
});
function get(query) {
var xhttp = new XMLHttpRequest();
xhttp.onreadystatechange = function() {
if (this.readyState == 4 && this.status == 200) {
document.getElementById("sample").innerHTML =
this.responseText;
}
};
xhttp.open("GET", "get?query=" + query, true);
xhttp.send();
};
</script>
推荐阅读
- ios - Razorpay 签名和订单 ID 未进入 onPaymentSuccess 的成功方法
- electron - Electron Forge Typescript+Webpack Boilerplate 不会为渲染器脚本生成源映射
- python - 使用数据框的不同列计算日期
- android - 根据 Android Studio 的建议删除多余的转义会导致应用崩溃
- sonarqube - 从外部/互联网访问 Windows 2019 服务器上的 Sonarqube
- node.js - 从 Node.js 的端点代码中提取异步函数
- android - EditTexts 值的总和
- salesforce - 授权组织时显示 ENOENT 错误
- ruby - 尝试在 VS 代码中运行调试时没有 launch.json 文件
- php - 找不到类“会话”(查看:C:\xampp\htdocs\LARAVEL\LARAVEL\resources\views\welcome.blade.php)