婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > ajax來自動補(bǔ)全表單字段示例

ajax來自動補(bǔ)全表單字段示例

熱門標(biāo)簽:上海浦東百度地圖標(biāo)注中心注冊 徐州電銷卡外呼系統(tǒng)供應(yīng)商 外呼系統(tǒng)獲取客戶手機(jī)號 百靈鳥 老虎郵局地圖標(biāo)注點(diǎn) 目標(biāo)三維地圖標(biāo)注 襄陽外呼系統(tǒng)接口 科智聯(lián)智能電銷機(jī)器人 青海醫(yī)療智能外呼系統(tǒng)怎么樣

源代碼:

腳本一:

!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; iallStates.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; istatesArray.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屬性(這個屬性是非標(biāo)準(zhǔn)兼容的)。
它告訴瀏覽器不要在這個字段上執(zhí)行任何自動補(bǔ)全,因為我們將用腳本處理自動補(bǔ)全。與XMLHttp-
Request一樣,盡管autocomplete不是任何W3C建議的一部分,但是它得到了很好的跨瀏覽器支持。
2. document.getElementById("searchField").onkeyup = searchSuggest;
為了捕捉和處理每次擊鍵,需要一個事件處理程序,這是在initAll()中設(shè)置的。
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; iallStates.length; i++) {
statesArray[i] = allStates[i].getElementsByTagName("label")[0].firstChild;
}
}

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

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

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

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

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

如果foundCt是1,我們就知道找到了唯一的匹配,所以可以將這個州名放進(jìn)字段。如果用戶已
經(jīng)輸入了ca,他們就不需要再輸入lifornia,因為我們已經(jīng)知道了他們要輸入哪個州名。我們使用
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 = "";
}

輸入州名的另一種方法是,單擊彈出列表中的一個州名。在這種情況下,會調(diào)用makeChoice()事
件處理程序。首先,我們通過檢查事件的目標(biāo),查明用戶單擊了哪個州名,這會提供一個特定的div。
查看這個div的innerHTML會提供州名,我們將這個州名放進(jìn)輸入字段。最后,清空可能值的彈出
列表。

您可能感興趣的文章:
  • asp.net+ajax+sqlserver自動補(bǔ)全功能實現(xiàn)解析
  • JSP + ajax實現(xiàn)輸入框自動補(bǔ)全功能 實例代碼
  • Ajax實現(xiàn)搜索引擎自動補(bǔ)全功能

標(biāo)簽:佛山 辛集 荊州 咸寧 商洛 紅河 揭陽 股票

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《ajax來自動補(bǔ)全表單字段示例》,本文關(guān)鍵詞  ajax,來,自動,補(bǔ)全,表單,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《ajax來自動補(bǔ)全表單字段示例》相關(guān)的同類信息!
  • 本頁收集關(guān)于ajax來自動補(bǔ)全表單字段示例的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    日韩国产在线观看一区| 首页综合国产亚洲丝袜| 麻豆精品新av中文字幕| 日本精品一区二区三区四区的功能| 日韩三级免费观看| 99精品视频中文字幕| 国产欧美一区二区精品性| 国产精品一二三| 日本aⅴ亚洲精品中文乱码| 欧美成人a在线| 国产真实乱对白精彩久久| 免费日韩伦理电影| 国产视频一区在线播放| 久久九九国产精品| 欧美精品一区二区三区高清aⅴ| 国产精品一品二品| 国产精品一区不卡| 一级做a爱片久久| 粉嫩绯色av一区二区在线观看| 美女视频网站久久| 国产精品久久久一本精品| 国产欧美日本一区二区三区| 91丝袜呻吟高潮美腿白嫩在线观看| 亚洲精品在线三区| 久久久亚洲高清| 欧美网站大全在线观看| 在线视频一区二区三区| 国产一区二区三区精品欧美日韩一区二区三区| 国产女主播一区| 国产精品毛片久久久久久| 精品视频在线视频| 亚洲欧美成人一区二区三区| 亚洲天堂成人在线观看| 欧美大白屁股肥臀xxxxxx| 色老头久久综合| 成人欧美一区二区三区在线播放| 4438x亚洲最大成人网| av电影天堂一区二区在线观看| 色综合天天综合网国产成人综合天 | 欧美亚一区二区| 捆绑紧缚一区二区三区视频| 国产一区二区美女| 三级成人在线视频| 精品国产污网站| 国产精品人人做人人爽人人添| 精品日本一线二线三线不卡| 国产日韩欧美亚洲| 亚洲精品一区二区三区福利| 久久国产精品第一页| av一区二区三区黑人| 国产精品一区二区在线播放| 在线欧美一区二区| 一本大道久久a久久综合| 亚洲欧美一区二区久久| 亚洲精品在线观看视频| 日韩一区二区三区视频在线观看| 色av成人天堂桃色av| 欧美久久久一区| 欧美日韩免费在线视频| 国产一区二区三区四区五区美女| 天天综合色天天综合色h| 亚洲动漫第一页| 日韩欧美国产一二三区| 欧美美女视频在线观看| 欧美一区二区大片| 欧美一区二区三区视频免费| 国产精品免费aⅴ片在线观看| 国产欧美日韩精品在线| 国产性天天综合网| 免费黄网站欧美| 九九精品视频在线看| 欧美视频中文一区二区三区在线观看| 一本大道久久a久久精二百| 麻豆成人在线观看| 欧美日韩视频专区在线播放| 欧美日韩在线不卡| 1024成人网| 亚洲成人先锋电影| 成人亚洲一区二区一| 色综合一个色综合亚洲| 欧美色偷偷大香| 亚洲精品中文字幕在线观看| 亚洲欧美欧美一区二区三区| 国产精品亚洲一区二区三区妖精| 国产乱理伦片在线观看夜一区| 一区二区三区在线观看网站| av不卡在线播放| 欧美精品成人一区二区三区四区| 欧美日韩成人综合| 国产亚洲欧洲一区高清在线观看| 亚洲国产精品99久久久久久久久| 成人欧美一区二区三区黑人麻豆 | 欧美乱妇一区二区三区不卡视频| 国产精品久久影院| 国产视频在线观看一区二区三区 | 8v天堂国产在线一区二区| 日韩亚洲欧美在线| 亚洲一级片在线观看| 免费亚洲电影在线| 日韩欧美中文字幕一区| 国产精品五月天| 亚洲成av人在线观看| 欧美日韩综合色| 国产蜜臀97一区二区三区| 福利一区二区在线观看| 在线免费视频一区二区| 亚洲一区二区综合| 国产盗摄女厕一区二区三区| 青青青爽久久午夜综合久久午夜| 91麻豆精品国产自产在线 | 91久久精品一区二区二区| 一区二区三区免费网站| 精品夜夜嗨av一区二区三区| 精品国产91亚洲一区二区三区婷婷 | 91麻豆精品国产综合久久久久久| 亚洲二区视频在线| www.欧美.com| 91女神在线视频| 一区二区三区波多野结衣在线观看| 久久99精品一区二区三区| 久久久www成人免费无遮挡大片| 亚洲高清一区二区三区| 日本一区免费视频| 日本韩国精品一区二区在线观看| 国产午夜精品久久久久久免费视 | 极品销魂美女一区二区三区| 国内精品久久久久影院一蜜桃| 国产三区在线成人av| 精品一区二区影视| 国产精品水嫩水嫩| 国产美女在线观看一区| 国产高清不卡二三区| 一色桃子久久精品亚洲| 福利电影一区二区| 午夜免费欧美电影| 色嗨嗨av一区二区三区| 欧美在线影院一区二区| 久草精品在线观看| 欧美日本精品一区二区三区| 国产一本一道久久香蕉| 久久一区二区三区国产精品| 国产一区91精品张津瑜| 久久精品免视看| 国产真实乱对白精彩久久| 一区二区三区中文字幕电影| 91色综合久久久久婷婷| 久久97超碰色| 中文字幕精品—区二区四季| 国产日韩欧美a| 免费成人性网站| 日韩免费观看高清完整版| 久久国内精品视频| 精品少妇一区二区三区视频免付费 | 不卡一区在线观看| 国产欧美精品国产国产专区| 最近中文字幕一区二区三区| 久久人人超碰精品| 99综合电影在线视频| 国产激情一区二区三区桃花岛亚洲| 欧洲人成人精品| 成人午夜精品一区二区三区| 一二三四社区欧美黄| 在线日韩国产精品| 色综合天天综合狠狠| 日韩成人精品视频| 亚洲成人动漫av| 91精品久久久久久久91蜜桃| 91免费国产视频网站| 亚洲123区在线观看| 极品少妇xxxx精品少妇偷拍| 免费人成在线不卡| 国产午夜精品一区二区三区视频| 韩日欧美一区二区三区| 亚洲精品乱码久久久久久黑人| 欧美体内she精高潮| 国产成人精品一区二区三区四区 | 91麻豆精品国产91| 欧美裸体一区二区三区| 青青草国产成人av片免费| 亚洲最大色网站| 日本精品裸体写真集在线观看| 欧美精品三级日韩久久| 在线免费观看成人短视频| 日本欧美加勒比视频| 日本伊人精品一区二区三区观看方式 | 99久久精品一区二区| 蜜臀精品一区二区三区在线观看 | 欧美日韩免费电影| 久久av中文字幕片| 国内国产精品久久| 亚洲一区在线观看免费观看电影高清| 亚洲欧美一区二区在线观看| 欧美mv日韩mv国产| 亚洲日本va午夜在线影院| 国产精品私人影院| 欧美一区二区免费| 久久综合成人精品亚洲另类欧美 | 亚洲午夜在线视频| 亚洲123区在线观看| 欧美丝袜丝交足nylons图片|