[英]How to display elements, refering to the selected radio button ? using pure javascript
[英]how to display popup to disable the search button while fetching/requesting data from the web server using Pure JavaScript?
我有这个页面:
<div>
<label id="lblchecked"></label>
<input id="ipt_search" type="search" title="Search" />
<button id="btn_search" onclick="loadXMLDoc();"> Search</button>
</div>
<div id="response">
<table id="tbl"></table>
</div>
<div id="openModal" class="modalDialog" style="display:none;">
<div>
<h2>Please wait .......... </h2>
</div>
</div>
在.js文件中,我从服务器获取数据为:
function loadXMLDoc() {
document.getElementById("openModal").style.display = "block";
var Searchtxt= document.getElementById("ipt_search").value;
var xhttp = new XMLHttpRequest();
xhttp.onreadystatechange = function () {
if (xhttp.readyState == 4 && xhttp.status == 200) {
var myArr = JSON.parse(xhttp.responseText);
myFunction(myArr);
}
};
xhttp.open("GET", "https://test.com/"+Searchtxt, true);
xhttp.send();
}
我要在获取服务器数据时使openModel
弹出并在数据加载后再次将其关闭。
在原始JavaScript中。
您需要稍微修改我们的onreadystatechange
事件处理程序,以在ajax请求完成后隐藏您的modalDialog
div。
function loadXMLDoc() {
var openModal = document.getElementById("openModal")
var Searchtxt = document.getElementById("ipt_search").value;
// show modal
openModal.style.display = "block";
var xhttp = new XMLHttpRequest();
xhttp.onreadystatechange = function () {
if (xhttp.readyState === 4) {
// http request completed
if (xhttp.status === 200) {
// successful
var myArr = JSON.parse(xhttp.responseText);
myFunction(myArr);
}
// hide modal, successful or not
openModal.style.display = 'none';
}
};
xhttp.open("GET", "https://test.com/"+Searchtxt, true);
xhttp.send();
};
此示例将在请求完成后关闭modalDialog
,但仅在请求成功后才调用myFunction()
。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.