首页 > web前端 > js教程 > 正文

使用 jQuery 动态创建 HTML 行时自动填充输入字段

心靈之曲
发布: 2025-08-31 21:15:01
原创
1031人浏览过

使用 jquery 动态创建 html 行时自动填充输入字段

本文档旨在解决在使用 JavaScript 动态创建 HTML 表格行后,如何使用 jQuery 自动填充这些行中的输入字段的问题。我们将探讨如何修改现有的 JavaScript 代码,以便正确地将当前行作为参数传递给填充函数,并使用类选择器来定位动态创建的输入字段,确保代码的健壮性和可维护性。

动态 HTML 行的自动填充

在使用 JavaScript 动态生成 HTML 表格行时,经常需要根据用户的输入或其他事件自动填充行中的其他输入字段。直接使用 ID 选择器可能会导致问题,因为 ID 在 HTML 文档中必须是唯一的。因此,使用类选择器和将当前行作为参数传递给处理函数是一种更有效的方法。

1. 修改 JavaScript 函数

首先,需要修改 GetDetail() 函数,使其能够接收当前行作为参数。这样,函数就可以在该行的上下文中查找输入字段,并更新它们的值。

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();
  }
}
登录后复制

在这个修改后的函数中,row 参数代表当前 HTML 行。我们使用 row.querySelector() 方法来查找该行中的具有特定类的输入字段,例如 .scode、.servproname 和 .qty。

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

怪兽AI数字人
怪兽AI数字人

数字人短视频创作,数字人直播,实时驱动数字人

怪兽AI数字人 44
查看详情 怪兽AI数字人

2. 修改 HTML 代码

接下来,需要修改 HTML 代码,以便将当前行作为参数传递给 GetDetail() 函数。此外,还需要将 ID 选择器替换为类选择器。

<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>
登录后复制

在这个修改后的 HTML 代码中,我们:

  • 使用 this.closest('tr') 来获取当前输入字段所在的最近的 zuojiankuohaophpcntr> 元素,并将其作为参数传递给 GetDetail() 函数。
  • 使用类选择器(例如 class="scode")代替 ID 选择器(例如 id="aaa")。

3. 总结和注意事项

  • ID 唯一性: 确保在 HTML 文档中使用唯一的 ID。对于动态创建的元素,应优先使用类选择器。
  • 参数传递: 将当前行作为参数传递给处理函数,可以确保函数在正确的上下文中操作。
  • 错误处理: 在实际应用中,应添加适当的错误处理机制,例如检查 xmlhttp.readyState 和 xmlhttp.status 的值,以及处理 JSON 解析错误。
  • 安全性: 注意对用户输入进行适当的验证和转义,以防止跨站脚本攻击 (XSS)。

通过以上步骤,可以有效地解决在使用 jQuery 动态创建 HTML 行时自动填充输入字段的问题。这种方法不仅适用于简单的表格,还可以扩展到更复杂的动态表单和用户界面。

以上就是使用 jQuery 动态创建 HTML 行时自动填充输入字段的详细内容,更多请关注php中文网其它相关文章!

HTML速学教程(入门课程)
HTML速学教程(入门课程)

HTML怎么学习?HTML怎么入门?HTML在哪学?HTML怎么学才快?不用担心,这里为大家提供了HTML速学教程(入门课程),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号