这篇文章主要介绍了如何使用ajax来自动补全表单字段,对ajax感兴趣的朋友可以参考下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>
<p id="popups"> </p>
</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 tempp = document.createelement("p");
tempp.innerhtml = thisstate;
tempp.onclick = makechoice;
tempp.classname = "suggestions";
document.getelementbyid("popups").appendchild(tempp);
}
}
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 thisp = evt.target;
}
else {
var thisp = window.event.srcelement;
}
document.getelementbyid("searchfield").value = thisp.innerhtml;
document.getelementbyid("popups").innerhtml = "";
}
分析如下:
1. please enter your state:<br>
<input type="text"id="searchfield" autocomplete="off"><br>
<p id="popups"> </p>
这是我们要注意的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 tempp = document.createelement("p");
tempp.innerhtml = thisstate;
tempp.onclick = makechoice;
tempp.classname = "suggestions";
document.getelementbyid("popups").appendchild(tempp);
因为这个州名是一个可能值,我们希望将它添加到要显示的列表中。实现方法是,创建一个临时
的p,将它的innerhtml设置为这个州名,添加onclick处理程序和classname,然后将整个p追
加到popups p中。将每个州名作为单独的p添加,这样我们就能够使用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中唯一的p填写输入字段,从而自动地提供完整的州名,然后清空popups p。
13.
function makechoice(evt) {
if (evt) {
var thisp = evt.target;
}
else {
var thisp = window.event.srcelement;
}
document.getelementbyid("searchfield").value = thisp.innerhtml;
document.getelementbyid("popups").innerhtml = "";
}
输入州名的另一种方法是,单击弹出列表中的一个州名。在这种情况下,会调用makechoice()事
件处理程序。首先,我们通过检查事件的目标,查明用户单击了哪个州名,这会提供一个特定的p。
查看这个p的innerhtml会提供州名,我们将这个州名放进输入字段。最后,清空可能值的弹出
列表。
相关推荐:
ajax实现图片预览与上传及生成缩略图的方法
jquery和iframe做一个ajax上传效果实例分享
ajax向服务端传递数组参数值实例详解
以上就是ajax来自动补全表单字段示例的详细内容。
