返回顶部
首页 > 资讯 > 前端开发 > JavaScript >使用ajax怎么自动补全表单字段
  • 422
分享到

使用ajax怎么自动补全表单字段

2024-04-02 19:04:59 422人浏览 独家记忆
摘要

这期内容当中小编将会给大家带来有关使用ajax怎么自动补全表单字段,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。源代码:脚本一:<!DOCTYPE htm

这期内容当中小编将会给大家带来有关使用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怎么自动补全表单字段了,如果刚好有类似的疑惑,不妨参照上述分析进行理解。如果想知道更多相关知识,欢迎关注编程网JavaScript频道。

--结束END--

本文标题: 使用ajax怎么自动补全表单字段

本文链接: https://lsjlt.com/news/74928.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • 使用ajax怎么自动补全表单字段
    这期内容当中小编将会给大家带来有关使用ajax怎么自动补全表单字段,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。源代码:脚本一:<!DOCTYPE htm...
    99+
    2024-04-02
  • 利用Ajax实现一个自动补全功能
    这篇文章将为大家详细讲解有关利用Ajax实现一个自动补全功能,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。如下图:天猫:京东:这时候的你是否想到如何实现这个功能?我们的网页明明没有刷新,可是...
    99+
    2023-05-31
    ajax 自动补全 全功能
  • CSS怎么实现自动补全字符串
    本文小编为大家详细介绍“CSS怎么实现自动补全字符串”,内容详细,步骤清晰,细节处理妥当,希望这篇“CSS怎么实现自动补全字符串”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。很多...
    99+
    2024-04-02
  • php之phpstorm自动代码补全怎么使用
    这篇文章主要讲解了“php之phpstorm自动代码补全怎么使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“php之phpstorm自动代码补全怎么使用”吧!phpstorm代码补全的设置...
    99+
    2023-06-30
  • mybatisplus之自动映射字段怎么使用
    这篇“mybatisplus之自动映射字段怎么使用”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“mybatisplus之自动...
    99+
    2023-07-05
  • eclipse自动补全怎么设置
    在Eclipse中,自动补全功能是默认开启的,但你可以根据自己的需求对其进行设置。要设置自动补全功能,可以按照以下步骤操作: 打...
    99+
    2024-04-02
  • Ajax实现关键字联想和自动补全功能及遇到坑
    目录遇到的小坑代码实现前端代码后端代码用到的实体类自己封装的jdbc工具类数据库表:效果展示:遇到的小坑 回调函数相对window.onload的摆放位置给回调函数addData传...
    99+
    2022-11-13
    ajax关键字自动补全 ajax关键字
  • eclipse使用--设置自动补全代码
    1、Java设置自动补全 (1)设置自动补全 依次点击Window --> Perferences(选项设置) --> Java --> Editor(编辑) --> Content Assist(内容辅助/代码提示) 然后在“Conte...
    99+
    2023-09-02
    eclipse java ide
  • Qt QCompleter自动补全怎么实现
    这篇“Qt QCompleter自动补全怎么实现”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Qt QC...
    99+
    2023-06-30
  • django怎么使用ajax提交表单
    在Django中使用Ajax提交表单,你需要进行以下步骤:1. 在你的HTML文件中,使用JavaScript编写一个函数来处理表单...
    99+
    2023-09-26
    django ajax
  • 怎么在php中使用phpstorm实现自动补全代码
    怎么在php中使用phpstorm实现自动补全代码?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。php的框架有哪些php的框架:1、Laravel,Laravel是一款免费...
    99+
    2023-06-14
  • php之phpstorm自动代码补全的使用
    php之phpstorm自动代码补全的使用 phpstorm代码补全的设置 打开首选项Editor、Live Templates。 点击PHP、右上角新增Live Template,点击下面的Define、勾选PHP 添加描述,Temp...
    99+
    2023-09-03
    PHP PHPstorm
  • Linux怎么实现自动补全命令
    这篇文章主要介绍“Linux怎么实现自动补全命令”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Linux怎么实现自动补全命令”文章能帮助大家解决问题。linux命令自动补全centos7下执行yum...
    99+
    2023-06-28
  • pycharm不能自动补全怎么解决
    如果PyCharm无法自动补全代码,可以尝试以下解决方法:1. 检查PyCharm的自动补全设置:在菜单栏中选择"File" -> ...
    99+
    2023-08-15
    pycharm
  • jquery中怎么隐藏表单字段
    这篇文章主要介绍“jquery中怎么隐藏表单字段”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“jquery中怎么隐藏表单字段”文章能帮助大家解决问题。首先,要隐藏一个表单字段,需要使用CSS中的&q...
    99+
    2023-07-05
  • MySQL表怎么创建自增字段
    本篇内容介绍了“MySQL表怎么创建自增字段”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!注:如果使用新的...
    99+
    2024-04-02
  • vue使用rules实现表单字段验证
    vue中表单字段验证的写法和方式有多种,本博客介绍三种较为常用的验证方式。 1. 写在 data 中验证 表单内容 <!-- 表单 --> <el-form r...
    99+
    2024-04-02
  • 怎么在Lavarel中使用ajax提交表单
    怎么在Lavarel中使用ajax提交表单?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。1,首先在模板里面加上一个meta  :<meta nam...
    99+
    2023-06-08
  • 利用eclipse怎么实现一个自动补全功能
    这期内容当中小编将会给大家带来有关利用eclipse怎么实现一个自动补全功能,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。解决代码的自动提示问题:打开 Eclipse -> Window ->...
    99+
    2023-05-31
    eclipse 全功能
  • springboot中自动建表无法更新字段怎么解决
    本篇内容主要讲解“springboot中自动建表无法更新字段怎么解决”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“springboot中自动建表无法更新字段怎么解决”吧!关于自动建表,无法更新字...
    99+
    2023-06-29
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作