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

使用 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。

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

2. 修改 HTML 代码

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

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

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

3. 总结和注意事项

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

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

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

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1518857.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月20日 11:56:02
下一篇 2025年12月19日 14:38:36

相关推荐

  • JavaScript正则表达式:精确提取复杂文本中的起始标识与日期

    本教程旨在解决在JavaScript中使用正则表达式从混合文本中提取特定模式的问题,特别是如何从包含HTML链接或简单名称以及标准日期时间格式的字符串中,高效地捕获从开头到第一个“GMT”标记的全部内容。通过采用非贪婪匹配和明确的结束锚点,我们能灵活应对起始部分的多样性,实现精确的数据提取。 引言与…

    好文分享 2025年12月20日
    000
  • 使用 jQuery 动态创建 HTML 行时实现自动填充

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

    好文分享 2025年12月20日
    000
  • 在GitHub上更新JSON文件:理解限制与正确方法

    本文旨在阐明通过客户端JavaScript直接修改GitHub上静态JSON文件的局限性,特别是涉及CORS策略的POST请求失败问题。我们将探讨为何这种直接操作不可行,介绍GitHub官方API作为文件更新途径,并最终推荐使用后端服务结合数据库的专业解决方案,以确保数据操作的安全性和可持续性。 1…

    2025年12月20日
    000
  • JavaScript实现HTML表格多列实时搜索功能

    本教程将指导您如何使用现代JavaScript和DOM操作,为HTML表格实现高效的多列实时搜索功能。通过利用forEach循环和Array.prototype.some()方法,我们将优化传统单列搜索逻辑,使用户能够同时在表格的所有列中查找匹配项,从而显著提升数据筛选的用户体验。 挑战:传统单列搜…

    2025年12月20日
    000
  • 如何在GitHub上通过API更新JSON文件内容及替代方案

    本文深入探讨了在GitHub Pages等静态托管环境中,为何无法直接通过客户端HTTP POST请求修改JSON文件内容,并解释了CORS错误的原因。教程将指导读者如何利用GitHub API进行文件更新,同时强调了客户端操作的潜在安全风险,并推荐使用专业的后端服务与数据库作为更健壮的动态数据管理…

    2025年12月20日
    000
  • 在GitHub上安全更新JSON文件:理解CORS限制与API应用实践

    本文深入探讨了在GitHub上直接通过客户端JavaScript修改JSON文件时遇到的CORS错误,并解释了其背后的安全原理。我们将介绍两种正确的解决方案:利用GitHub REST API进行文件内容管理,以及更健壮的后端服务与数据库方案,旨在帮助开发者理解并实践安全有效的数据更新策略。 问题剖…

    2025年12月20日
    000
  • JavaScript实现HTML表格多列搜索:优化用户体验

    本教程详细介绍了如何使用JavaScript实现HTML表格的多列搜索功能。通过优化现有单列搜索逻辑,我们利用Array.prototype.some()方法高效遍历表格行中的所有单元格(),实现对任意列内容的实时匹配,从而显著提升用户在大型数据集中的查找效率和体验。 在网页开发中,为html表格添…

    2025年12月20日
    000
  • Puppeteer 爬取网页数据返回空数组问题解决方案

    本文针对使用 Puppeteer 爬取 naamhinaam.com 网站数据时,出现返回空数组的问题,提供了一套可行的解决方案。通过分析问题代码,找出选择器和循环逻辑上的错误,并提供优化后的代码示例,确保能正确抓取网页上的婴儿名字和含义信息,并避免因广告元素干扰导致的问题。本文还强调了headle…

    2025年12月20日
    000
  • 使用 Puppeteer 抓取网页数据返回空数组的解决方案

    本文旨在解决在使用 Puppeteer 抓取网页数据时,遇到返回空数组的问题。通过分析问题代码,找到导致问题的原因,并提供修正后的代码示例,确保能正确抓取目标网站的数据,并清晰地呈现抓取结果。本文重点关注选择器的使用和异步操作的处理,帮助开发者避免类似问题。 在使用 Puppeteer 进行网页数据…

    2025年12月20日
    000
  • 使用 Puppeteer 抓取网页数据返回空数组问题的解决方案

    本文旨在解决在使用 Puppeteer 抓取网页数据时,遇到返回空数组的问题。通过分析常见原因,并提供优化后的代码示例,帮助开发者更有效地抓取目标网站的数据,并避免抓取结果为空的情况。本文将重点关注选择器优化、页面元素加载以及数据提取等关键环节。 问题分析 在使用 Puppeteer 进行网页数据抓…

    2025年12月20日
    000
  • 使用 Puppeteer 抓取网页数据时返回空数组的解决方案

    本文旨在解决在使用 Puppeteer 抓取网页数据时,最终返回空数组的问题。通过分析问题代码,找出导致问题的根源,并提供一份经过修改的、能够正确抓取目标数据的示例代码。本文档将指导开发者避免常见的 Puppeteer 使用错误,并掌握更有效的数据提取技巧。 在使用 Puppeteer 进行网页数据…

    2025年12月20日
    000
  • GitHub Pages上JSON数据动态更新的挑战与最佳实践:告别客户端直写

    本文探讨了在GitHub Pages上通过客户端JavaScript(如Axios)直接修改JSON文件时遇到的CORS错误及其根本原因。我们将解释为何静态文件服务不支持此类操作,并介绍GitHub API作为一种间接方式,但重点强调了其安全局限性。最终,文章将推荐使用专业的后端服务与数据库,作为实…

    2025年12月20日
    000
  • 使用 jQuery 获取 HTML 数据表格中未选中行的值

    本文旨在提供一种使用 JavaScript 获取 HTML 数据表格中,在点击某行按钮后,获取所有其他未被点击行的数据的方法。我们将通过监听按钮的点击事件,向上查找父元素 ,然后获取其兄弟元素,最终提取所需数据。 在 HTML 数据表格中,有时我们需要在用户点击某一行后,获取其他行的信息。例如,当用…

    2025年12月20日
    000
  • 从HTML表格中获取非选中行数据的JavaScript教程

    本教程详细讲解如何使用纯JavaScript在HTML表格中,当点击某行按钮时,高效地获取所有其他未被选中行的数据。文章通过事件监听、DOM遍历和自定义函数,提供了一套清晰的解决方案,并附带示例代码和注意事项,帮助开发者准确实现这一功能。 引言 在网页开发中,表格是展示和管理结构化数据的常用元素。用…

    2025年12月20日
    000
  • 获取HTML表格中未选中行的值:jQuery实现教程

    本文旨在提供一种使用jQuery获取HTML表格中未选中行数据的实用方法。通过监听按钮点击事件,获取当前点击按钮所在行的兄弟节点(即其他行),并提取这些行中的数据,最终将结果输出。本文将详细讲解实现步骤,并提供完整的代码示例,帮助开发者快速掌握该技巧。 在Web开发中,经常会遇到需要获取表格中特定行…

    2025年12月20日
    000
  • 使用 jQuery 获取 HTML 数据表格中未选中行的数据

    本文旨在介绍如何使用 jQuery 获取 HTML 数据表格中,除点击行之外的所有行的数据。我们将通过监听按钮点击事件,获取点击按钮所在行的兄弟节点,并提取这些兄弟节点中的数据,最终将这些数据组合成字符串输出。 在处理 HTML 数据表格时,有时我们需要获取除当前选中行之外的所有行的数据。这在需要进…

    2025年12月20日
    000
  • JavaScript中获取HTML表格非选中行数据的技术指南

    本教程详细阐述了如何在HTML数据表中,当用户点击某一行内的按钮时,高效地获取并处理所有非选中行(即未被点击行)的数据。通过事件监听和DOM遍历技术,我们将学习如何识别被点击行,进而定位其兄弟元素(非选中行),并提取所需的数据,适用于需要对表格中除特定行外的其他数据进行操作的场景。 在web开发中,…

    2025年12月20日
    000
  • 什么是CommonJS和ES模块?

    CommonJS采用同步加载和值拷贝,模块导出的是静态值;ES模块支持异步加载和动态引用,导出绑定保持实时更新,两者在加载机制、缓存策略及变量绑定上存在本质差异。 CommonJS和ES模块是JavaScript中两种主要的模块化规范,它们定义了代码如何被组织、导入和导出。CommonJS主要用于N…

    2025年12月20日
    000
  • 浏览器JS线程模型是什么?

    JavaScript在浏览器中是单线程的,通过事件循环机制实现异步非阻塞操作。主线程负责执行JS代码、渲染页面和处理用户交互,为避免DOM操作冲突,一次只能执行一个任务。耗时操作由浏览器的Web APIs处理,完成后将回调放入任务队列。事件循环在执行栈空闲时,优先执行微任务队列中的任务(如Promi…

    2025年12月20日
    000
  • 什么是JS的Proxy对象?

    Proxy对象通过拦截操作实现对象行为的自定义,其核心是new Proxy(target, handler),handler中的陷阱如get、set可实现数据校验与日志记录,相比Object.defineProperty,Proxy能监听属性增删及更多操作,支持13种陷阱,覆盖对象操作全方面,结合R…

    2025年12月20日
    000

发表回复

登录后才能评论
关注微信