值得一看
广告
彩虹云商城
广告

热门广告位

使用 jQuery 动态创建 HTML 行时实现自动填充

使用 jquery 动态创建 html 行时实现自动填充

本文旨在解决在使用 JavaScript 动态创建 HTML 表格行后,如何利用 jQuery 实现输入框自动填充的问题。文章将详细介绍如何修改现有的 JavaScript 代码,使其能够正确地定位到动态创建的行中的输入字段,并使用类选择器代替 ID 选择器,避免 ID 重复问题。同时,提供修改后的代码示例,以帮助读者更好地理解和应用。

动态创建 HTML 元素是 Web 开发中常见的需求,尤其是在处理表格数据时。然而,在动态创建的元素上应用 jQuery 功能时,可能会遇到一些问题,例如无法正确地选择到目标元素。本教程将针对动态创建的表格行,讲解如何使用 jQuery 实现输入框的自动填充功能。

关键问题:ID 的唯一性与动态元素的选择

在使用 jQuery 操作 HTML 元素时,经常会使用 ID 选择器。但是,ID 在 HTML 文档中必须是唯一的。如果在动态创建的行中使用相同的 ID,会导致 ID 冲突,使得 jQuery 无法正确地选择到目标元素。

解决方案:使用类选择器和传递上下文

为了解决 ID 冲突的问题,应该使用类选择器(class selector)代替 ID 选择器。同时,需要将当前行(row)作为参数传递给 GetDetail() 函数,以便在该函数内部能够正确地定位到当前行中的输入字段。

立即学习“前端免费学习笔记(深入)”;

代码示例

以下是修改后的 JavaScript 代码:

function GetDetail(row) {
let str = row.querySelector(".scode").value;
if (str.length == 0) {
row.querySelector(".servproname").value = "";
row.querySelector(".qty").value = "";
return;
} else {
// Creates a new XMLHttpRequest object
var xmlhttp = new XMLHttpRequest();
xmlhttp.onreadystatechange = function() {
// Defines a function to be called when
// the readyState property changes
if (this.readyState == 4 &&
this.status == 200) {
// Typical action to be performed
// when the document is ready
var myObj = JSON.parse(this.responseText);
// Returns the response data as a
// string and store this array in
// a variable assign the value
// received to first name input field
row.querySelector(".servproname").value = myObj[0];
row.querySelector(".qty").value = myObj[1];
}
};
// xhttp.open("GET", "filename", true);
xmlhttp.open("GET", "gfg.php?user_id=" + str, true);
// Sends the request to the server
xmlhttp.send();
}
}

在 HTML 中,将 ID 替换为 class,并将当前行传递给 GetDetail() 函数:

<table>
<tr>
<td><input type="text" class="scode form-control text-end" name="scode[]" onkeyup="GetDetail(this.closest('tr'))" value=""></td>
<td><input type="text" class="servproname form-control text-end" name="servproname[]"></td>
<td><input type="text" class="qty form-control text-end" name="qty[]" onchange="Calc(this);"></td>
</tr>
</table>

代码解释:

  • GetDetail(row) 函数: 该函数接收一个 row 参数,代表当前表格行。
  • row.querySelector(“.className”): 使用 querySelector() 方法在当前行中查找具有指定 class 的元素。
  • this.closest(‘tr’): 在 onkeyup 事件中,this 指向触发事件的输入框。closest(‘tr’) 方法用于查找最近的父级 zuojiankuohaophpcntr> 元素,即当前表格行。

注意事项

  • 确保在动态创建 HTML 元素后,再绑定事件处理程序。
  • 使用类选择器代替 ID 选择器,避免 ID 冲突。
  • 仔细检查代码中的选择器,确保它们能够正确地定位到目标元素。
  • 在进行 AJAX 请求时,注意处理错误情况,例如网络连接错误或服务器返回错误。

总结

通过使用类选择器和传递上下文,可以有效地解决在使用 jQuery 操作动态创建的 HTML 元素时遇到的问题。本教程提供了一个具体的示例,展示了如何使用 jQuery 实现动态创建的表格行中输入框的自动填充功能。希望本教程能够帮助读者更好地理解和应用 jQuery。

温馨提示: 本文最后更新于2025-08-31 22:39:45,某些文章具有时效性,若有错误或已失效,请在下方留言或联系在线客服
文章版权声明 1 本网站名称: 创客网
2 本站永久网址:https://new.ie310.com
1 本文采用非商业性使用-相同方式共享 4.0 国际许可协议[CC BY-NC-SA]进行授权
2 本站所有内容仅供参考,分享出来是为了可以给大家提供新的思路。
3 互联网转载资源会有一些其他联系方式,请大家不要盲目相信,被骗本站概不负责!
4 本网站只做项目揭秘,无法一对一教学指导,每篇文章内都含项目全套的教程讲解,请仔细阅读。
5 本站分享的所有平台仅供展示,本站不对平台真实性负责,站长建议大家自己根据项目关键词自己选择平台。
6 因为文章发布时间和您阅读文章时间存在时间差,所以有些项目红利期可能已经过了,能不能赚钱需要自己判断。
7 本网站仅做资源分享,不做任何收益保障,创业公司上收费几百上千的项目我免费分享出来的,希望大家可以认真学习。
8 本站所有资料均来自互联网公开分享,并不代表本站立场,如不慎侵犯到您的版权利益,请联系79283999@qq.com删除。

本站资料仅供学习交流使用请勿商业运营,严禁从事违法,侵权等任何非法活动,否则后果自负!
THE END
喜欢就支持一下吧
点赞9赞赏 分享
评论 抢沙发

请登录后发表评论

    暂无评论内容