亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

使用ajax怎么自動補全表單字段

發布時間:2021-07-22 15:44:27 來源:億速云 閱讀:146 作者:Leah 欄目:web開發

這期內容當中小編將會給大家帶來有關使用ajax怎么自動補全表單字段,文章內容豐富且以專業的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

源代碼:

腳本一:

<!DOCTYPE html>
<html>
<head>
<title>Auto-fill Form Fields</title>
<link rel="stylesheet"href="script06.css" rel="external nofollow" >
<script src="script06.js"></script>
</head>
<body>
<form action="#">
Please enter your state:<br>
<input type="text" id="searchField" autocomplete="off"><br>
<div id="popups"> </div>
</form>
</body>
</html>

腳本二:

body, #searchfield {
font: 1.2em arial, helvetica,sans-serif;
}
.suggestions {
background-color: #FFF;
padding: 2px 6px;
border: 1px solid #000;
}
.suggestions:hover {
background-color: #69F;
}
#popups {
position: absolute;
}
#searchField.error {
background-color: #FFC;
}

腳本三:

window.onload = initAll;
var xhr = false;
var statesArray = new Array();
function initAll() {
document.getElementById("searchField").onkeyup = searchSuggest;
if (window.XMLHttpRequest) {
xhr = new XMLHttpRequest();
}
else {
if (window.ActiveXObject) {
try {
xhr = new ActiveXObject("Microsoft.XMLHTTP");
}
catch (e) { }
}
}
if (xhr) {
xhr.onreadystatechange = setStatesArray;
xhr.open("GET", "us-states.xml",true);
xhr.send(null);
}
else {
alert("Sorry, but I couldn't create an XMLHttpRequest");
}
}
function setStatesArray() {
if (xhr.readyState == 4) {
if (xhr.status == 200) {
if (xhr.responseXML) {
var allStates = xhr.responseXML.getElementsByTagName("item");
for (var i=0; i<allStates.length; i++) {
statesArray[i] = allStates[i].getElementsByTagName("label")[0].firstChild;
}
}
}
else {
alert("There was a problem with the request " + xhr.status);
}
}
}
function searchSuggest() {
var str = document.getElementById("searchField").value;
document.getElementById("searchField").className = "";
if (str != "") {
document.getElementById("popups").innerHTML = "";
for (var i=0; i<statesArray.length;i++) {
var thisState = statesArray[i].nodeValue;
if (thisState.toLowerCase().indexOf(str.toLowerCase())== 0) {
var tempDiv = document.createElement("div");
tempDiv.innerHTML = thisState;
tempDiv.onclick = makeChoice;
tempDiv.className = "suggestions";
document.getElementById("popups").appendChild(tempDiv);
}

}
var foundCt = document.getElementById("popups").childNodes.length;
if (foundCt == 0) {
document.getElementById("searchField").className ="error";
}
if (foundCt == 1) {
document.getElementById("searchField").value = document.getElementById("popups").
firstChild.innerHTML;
document.getElementById("popups").innerHTML = "";
}
}
}
function makeChoice(evt) {
if (evt) {
var thisDiv = evt.target;
}
else {
var thisDiv = window.event.srcElement;
}
document.getElementById("searchField").value = thisDiv.innerHTML;
document.getElementById("popups").innerHTML = "";
}

分析如下:

1. Please enter your state:<br>
<input type="text"id="searchField" autocomplete="off"><br>
<div id="popups"> </div>
這是我們要注意的HTML代碼。其中的特殊之處是autocomplete屬性(這個屬性是非標準兼容的)。
它告訴瀏覽器不要在這個字段上執行任何自動補全,因為我們將用腳本處理自動補全。與XMLHttp-
Request一樣,盡管autocomplete不是任何W3C建議的一部分,但是它得到了很好的跨瀏覽器支持。
2. document.getElementById("searchField").onkeyup = searchSuggest;
為了捕捉和處理每次擊鍵,需要一個事件處理程序,這是在initAll()中設置的。
3. xhr.onreadystatechange =setStatesArray;
xhr.open("GET", "us-states.xml",true);
xhr.send(null);

4.

if (xhr.responseXML) {
var allStates = xhr.responseXML.getElementsByTagName("item");
for (var i=0; i<allStates.length; i++) {
statesArray[i] = allStates[i].getElementsByTagName("label")[0].firstChild;
}
}

我們在這里讀取文件,查看每個item節點,尋找其中的label節點,并且存儲label的firstChild
(州名本身)。每個州名存儲在statesArray數組中的一個元素中。
5. var str = document.getElementById("searchField").value;
document.getElementById("searchField").className = "";
當開始在字段中進行輸入時,就會執行searchSuggest()事件處理程序中的代碼。首先獲得
searchField的值,也就是到目前為止已經輸入的信息。接下來,清空這個字段的class屬性。

6. if (str != "") {
document.getElementById("popups").innerHTML = "";
如果還沒有輸入任何信息,就不做任何事,所以在這里進行檢查,確保用戶已經輸入了某個值,
然后再彈出可能值的列表。如果已經輸入了某些信息,就清空以前的可能值列表。
7. for (var i=0; i<statesArray.length; i++) {
var thisState = statesArray[i].nodeValue;
現在,遍歷州名的列表,并且將當前查看的州名存儲在thisState中。
8. if (thisState.toLowerCase().indexOf(str.toLowerCase())== 0) {
我們希望檢查用戶到目前為止輸入的內容是否某個州名的一部分——但是僅僅這樣還不夠,我們
還必須確保輸入的內容位于州名的開頭。畢竟,如果輸入了Kansas,你并不希望下拉框中顯示Arkansas
或Kansas。另外,在進行這項檢查時,還在檢查indexOf()之前確保兩個字符串都是小寫的。
如果indexOf()返回0(也就是說,在thisState的開頭位置處找到了輸入的字符串),那么我們
就知道找到了一個匹配。
9.

var tempDiv = document.createElement("div");
tempDiv.innerHTML = thisState;
tempDiv.onclick = makeChoice;
tempDiv.className = "suggestions";
document.getElementById("popups").appendChild(tempDiv);

因為這個州名是一個可能值,我們希望將它添加到要顯示的列表中。實現方法是,創建一個臨時
的div,將它的innerHTML設置為這個州名,添加onclick處理程序和className,然后將整個div追
加到popups div中。將每個州名作為單獨的div添加,這樣我們就能夠使用JavaScript和CSS操作每
個州名。
10. var foundCt = document.getElementById("popups").childNodes.length;
當遍歷完所有州名之后,我們要建立彈出窗口——但是我們得到了多少個州名呢?這里就計算這
個值:foundCt。
11. if (foundCt == 0) {
document.getElementById("searchField").className = "error";
}
如果foundCt是0,就說明用戶輸入了錯誤的內容。我們將className設置為error,從而讓用戶
知道輸入錯了,這一設置會使輸入字段顯示淺黃色背景(這由腳本13-17中的CSS樣式規則控制)。
12. 

if (foundCt == 1) {
document.getElementById("searchField").value = document.getElementById
?("popups").firstChild.innerHTML;
document.getElementById("popups").innerHTML = "";
}

如果foundCt是1,我們就知道找到了唯一的匹配,所以可以將這個州名放進字段。如果用戶已
經輸入了ca,他們就不需要再輸入lifornia,因為我們已經知道了他們要輸入哪個州名。我們使用
popups中唯一的div填寫輸入字段,從而自動地提供完整的州名,然后清空popups div。
13.

 function makeChoice(evt) {
if (evt) {
var thisDiv = evt.target;
}
else {

var thisDiv = window.event.srcElement;
}
document.getElementById("searchField").value = thisDiv.innerHTML;
document.getElementById("popups").innerHTML = "";
}

上述就是小編為大家分享的使用ajax怎么自動補全表單字段了,如果剛好有類似的疑惑,不妨參照上述分析進行理解。如果想知道更多相關知識,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

宁津县| 滨州市| 静安区| 泽普县| 古丈县| 米林县| 来凤县| 宁国市| 鹤庆县| 孟州市| 阿拉善左旗| 石河子市| 宣恩县| 隆尧县| 乐山市| 石台县| 垦利县| 都江堰市| 阜康市| 靖江市| 鹤壁市| 忻城县| 青龙| 永和县| 乌兰浩特市| 茂名市| 上思县| 会同县| 庆元县| 阿鲁科尔沁旗| 阜宁县| 舞阳县| 满洲里市| 外汇| 柏乡县| 普洱| 安乡县| 平阳县| 福泉市| 黑山县| 屏山县|