如何在点击的Div中获取正确的ID

如何在点击的div中获取正确的id

本文旨在解决动态生成的HTML元素中,点击事件发生时,如何准确获取与该元素关联的ID值的问题。通过事件委托和DOM遍历,我们将提供一种可靠的方法,确保在复杂的动态环境中,始终能获取到正确的ID,避免因选择器错误而导致的数据获取错误。

在动态生成的HTML结构中,经常会遇到点击事件需要获取特定ID的情况。如果直接使用jQuery选择器,可能会因为DOM结构的变化或选择器范围过大而导致获取到错误的ID。本文将介绍如何使用事件委托和DOM遍历,准确地获取与点击元素相关的ID。

问题分析

原始代码的问题在于,点击.histor-uten元素时,$(“input[name=’id_utt’]”).val() 总是返回第一个匹配的input元素的value,而不是当前点击的.histor-uten元素内部的input元素的value。这是因为选择器$(“input[name=’id_utt’]”)会选择页面上所有name属性为id_utt的input元素,并返回第一个匹配项的值。

解决方案:事件委托与DOM遍历

解决此问题的关键在于:

事件委托: 将事件监听器绑定到父元素,利用事件冒泡机制,监听子元素的点击事件。DOM遍历: 在事件处理函数中,通过DOM遍历,找到当前点击元素内部的input元素,并获取其value。

以下是修改后的代码:

var data = [    { codigo: "1", Utente: "Teste" },    { codigo: "2", Utente: "Teste1" },    { codigo: "3", Utente: "Teste2" },    { codigo: "4", Utente: "Teste3" },    { codigo: "5", Utente: "Teste4" },    { codigo: "6", Utente: "Teste5" },];$(document).on('click', '.dad-inf', function() {    var linha = ``;    for (var i = 0; i < data.length; i++) {        codigo = data[i].codigo;        Utente = data[i].Utente;        linha += ``;    }    $(".tesssste").html(linha);});$(document).on('click', '.histor-uten', function(e) {    let parent = $(this);    // First make sure it selects the element with the histor-uten class    if (!parent.hasClass('histor-uten')) {        parent = $(this).closest('.histor-uten');    }    // Get the child input from the parent instead of the first one in the document    var id_utt = $(parent.find("input[name='id_utt']")).val();    console.log(id_utt);});$(function() {    $(".btn-show").click(function(e) {        e.preventDefault();        el = $(this).data('element');        $(el).show();        $("section > div").not(el).hide();    });});

代码解释:

$(document).on(‘click’, ‘.histor-uten’, function(e) { … });: 使用事件委托,将点击事件监听器绑定到document,监听所有.histor-uten元素的点击事件。 这样做的好处是,即使.histor-uten元素是动态生成的,也能正确绑定事件。let parent = $(this);: 获取当前点击的.histor-uten元素。$(this)指向触发事件的DOM元素。if (!parent.hasClass(‘histor-uten’)) { parent = $(this).closest(‘.histor-uten’); }: 确保 parent 变量指向 .histor-uten 元素。 如果点击事件发生在 .histor-uten 元素的子元素上,则使用 .closest() 方法找到最近的父元素 .histor-uten。var id_utt = $(parent.find(“input[name=’id_utt’]”)).val();: 使用parent.find(“input[name=’id_utt’]”)在当前点击的.histor-uten元素内部查找name属性为id_utt的input元素,并获取其value。

完整示例

    Get ID Example                Utentes    
var data = [ { codigo: "1", Utente: "Teste" }, { codigo: "2", Utente: "Teste1" }, { codigo: "3", Utente: "Teste2" }, { codigo: "4", Utente: "Teste3" }, { codigo: "5", Utente: "Teste4" }, { codigo: "6", Utente: "Teste5" }, ]; $(document).on('click', '.dad-inf', function() { var linha = ``; for (var i = 0; i < data.length; i++) { codigo = data[i].codigo; Utente = data[i].Utente; linha += ``; } $(".tesssste").html(linha); }); $(document).on('click', '.histor-uten', function(e) { let parent = $(this); // First make sure it selects the element with the histor-uten class if (!parent.hasClass('histor-uten')) { parent = $(this).closest('.histor-uten'); } // Get the child input from the parent instead of the first one in the document var id_utt = $(parent.find("input[name='id_utt']")).val(); console.log(id_utt); }); $(function() { $(".btn-show").click(function(e) { e.preventDefault(); el = $(this).data('element'); $(el).show(); $("section > div").not(el).hide(); }); });

注意事项

确保事件委托的父元素存在于DOM中。DOM遍历时,选择器要足够精确,避免选择到错误的元素。如果HTML结构发生变化,需要相应地调整DOM遍历的代码。

总结

通过使用事件委托和DOM遍历,可以准确地获取动态生成的HTML元素中与点击事件相关的ID。这种方法避免了全局选择器可能导致的问题,提高了代码的健壮性和可维护性。在复杂的Web应用中,掌握这些技巧至关重要。

以上就是如何在点击的Div中获取正确的ID的详细内容,更多请关注创想鸟其它相关文章!

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

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
长列表滚动加载时,scrollTop值不精确导致分页加载出错怎么办?
上一篇 2026年5月10日 11:07:48
基于用户语言环境定制 Laravel 通知
下一篇 2026年5月10日 11:07:50

相关推荐

  • Go与PHP HTTP POST请求签名差异解析与实践

    本文深入探讨了在%ignore_a_1%中实现http post请求时,与php curl行为的差异,尤其是在处理请求体和签名生成方面。文章指出go的`http.request`在发送post请求时会忽略`form`字段而只使用`body`,这与php中直接将查询字符串作为post字段的行为不同。通…

    2026年5月10日
    000
  • C++怎么使用Google Benchmark进行性能测试_C++性能分析与Benchmark工具使用

    Google Benchmark可精确测量C++函数性能,通过克隆源码、CMake编译安装后,用BENCHMARK宏编写测试,结合volatile和DoNotOptimize防止优化,编译时链接benchmark库,运行后输出执行时间与迭代次数,并支持参数化测试以评估不同数据规模下的性能表现。 在C…

    2026年5月10日
    000
  • css权重是什么?css权重的介绍

    本篇文章给大家带来的内容是关于css权重是什么?css权重的介绍,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 1、什么是css权重?css6大基础选择器 css权重指的是css6大基础选择符的优先级,优先级高的css样式会覆盖优先级底的css样式,优先级越高说明权重越高,反之亦然…

    2026年5月10日
    100
  • Golang环境变量调试与问题排查示例

    答案:调试Go环境变量需先打印确认值是否正确,常见问题包括未生效、.env文件未加载、拼写错误及容器中丢失变量,应使用os.Getenv或os.LookupEnv获取,并通过日志记录辅助排查。 在Go语言开发中,环境变量常用于配置应用程序行为,比如切换运行模式(开发/生产)、设置数据库连接、控制日志…

    2026年5月10日
    200
  • PyInstaller打包应用时的数据文件依赖管理

    本文深入探讨了PyInstaller打包Python程序为可执行文件时,如何有效处理非脚本类数据文件(如文本文件、图片等)的依赖问题。核心解决方案是确保可执行文件与这些数据文件位于同一目录下,以保证程序能正确访问它们。文章将通过示例说明常见错误场景,并提供最佳实践,帮助开发者构建功能完整的独立应用。…

    2026年5月10日
    000
  • JavaScript 实现链接样式动态切换教程

    本教程详细介绍了如何使用 JavaScript 的 classList.toggle 方法,在点击链接时实现其CSS类的动态切换,从而改变链接的视觉样式。文章通过具体代码示例,解释了如何正确地在两个互斥类之间进行切换,并提供了相关的最佳实践和注意事项,帮助开发者创建交互式用户界面。 动态切换链接样式…

    2026年5月10日
    000
  • JavaScript 精准元素样式修改:避免全局操作影响局部组件

    本文旨在解决javascript事件处理中常见的子元素样式全局修改问题。通过分析使用`document.getelementsbyclassname`的局限性,我们将演示如何利用`element.queryselector`方法,在父元素被点击时,精准地定位并修改其内部特定子元素的样式,从而避免不必…

    2026年5月10日
    200
  • 如何使用CSS的Grid布局实现小松鼠邮票的效果(附源码)

    本篇文章给大家带来的内容是关于如何使用css的grid布局实现小松鼠邮票的效果(附源码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 效果预览 源代码下载 每日前端实战系列的全部源代码请从 github 下载: https://github.com/comehope/front-…

    2026年5月10日
    000
  • 在vscode中怎么运行html_vscode运行html文件方法【教程】

    1、使用Live Server扩展可实现自动刷新预览,安装后右键选择Open with Live Server即可在浏览器中实时查看HTML页面效果。 如果您在使用VSCode编写HTML文件,但不知道如何快速预览页面效果,可以通过多种方式在浏览器中运行HTML文件。以下是几种常用的实现方法: 一、…

    2026年5月10日
    000
  • 优化Django REST Framework嵌套序列化实现多模型用户注册

    核心挑战:多模型数据注册与嵌套序列化 在开发复杂的Web应用时,我们经常会遇到一个用户注册流程需要同时创建或更新多个关联模型实例的情况。例如,一个“骑手”注册不仅涉及创建基础的用户账户(CustomUser),还需要创建骑手专属的个人资料(Rider),其中包含车辆信息、服务能力等。传统的嵌套序列化…

    2026年5月10日
    000
  • 自定义HTML视频控件:精确控制键盘快进/快退行为

    本教程详细讲解如何自定义HTML “ 元素的默认键盘控制行为,特别是左右箭头键的视频快进/快退步长。文章指出,仅使用 `event.preventDefault()` 不足以完全阻止浏览器默认行为,还需要结合 `event.stopPropagation()` 来确保自定义逻辑独立生效,从而实现精…

    2026年5月10日
    000
  • 用css解决标题显示字数超出省略号代替的方法

    标题字数超出场景: 最左边这栏我不行让他换行,怎么办呢? 步骤一:内容超出宽度时隐藏超出部分的内容 步骤二:当对象内文本溢出时显示省略标记(…) 立即学习“前端免费学习笔记(深入)”; 下面是解决办法: table{width:100px;table-layout:fixed;/* 只有…

    2026年5月10日
    000
  • 在HTML文件中嵌入Mermaid图表教程

    本教程详细介绍了如何在HTML文件中直接嵌入和渲染Mermaid图表。通过引入Mermaid CDN库并进行简单的初始化配置,用户可以轻松地在网页中展示流程图、时序图、甘特图等多种类型的图表,无需依赖外部工具或复杂的构建流程,实现图表内容的动态化与可视化。 引言:Mermaid图表与HTML集成 M…

    2026年5月10日
    100
  • Go语言高效素数生成:Atkin筛法实践与解析

    本文深入探讨在go语言中高效生成素数的方法。针对简单模运算判断素数的不足,我们将介绍并详细演示atkin筛法,这是一种优化后的素数筛选算法。通过go语言代码实现,读者将学习如何利用该算法在给定范围内快速准确地找出所有素数,并理解其核心逻辑与应用细节,从而提升素数生成效率。 1. 素数及其识别挑战 素…

    2026年5月10日
    000
  • HTML代码怎么实现版本控制_HTML代码版本控制方法与Git工具使用指南

    HTML代码需要版本控制以实现错误回溯、团队协作、功能迭代和代码审计,使用Git可通过初始化仓库、添加文件、提交修改、推送至远程仓库等步骤管理代码,常用命令包括git status、git diff、git log等,冲突时需手动编辑解决并重新提交。 HTML代码的版本控制,简单来说,就是追踪和管理…

    2026年5月10日
    000
  • 关于CSS选择器种类及使用介绍

    常用的有标签选择器、类选择器、ID选择器等等,其实还有很多,在接下来的文章中为大家详细介绍下这些选择器的种类及其使用 首先说主要都有哪些先择器 1.标签选择器(如:body,p,p,ul,li) 2.类选择器(如:class=”head”,class=”head_…

    用户投稿 2026年5月10日
    000
  • 学习 Django 时的关键主题

    1. Django 基础知识 项目结构:了解 Django 项目的基本结构(例如,settings.py、urls.py、wsgi.py)。应用程序:了解 Django 应用程序如何在项目中工作以及如何创建和管理它们。URL 和路由:定义 URL 模式并将它们链接到视图。视图:编写基于函数的视图(F…

    2026年5月10日
    100
  • Angular中如何通过点击区域外来隐藏组件内容?

    巧妙运用angular指令,轻松实现点击区域外隐藏组件 在Angular应用开发中,常遇到需要在点击组件外部区域时隐藏该组件的需求,例如点击下拉菜单外部关闭菜单。本文将介绍如何使用ng-click-outside指令优雅地解决此问题。 首先,你需要安装ng-click-outside依赖: npm …

    2026年5月10日
    000
  • Go语言全局日志器Lumber的配置与使用

    本文将详细介绍在go语言中,如何通过声明包级别变量的方式,实现`github.com/jcelliott/lumber`等日志库的全局访问。这种方法允许在`main`函数外部的任何函数中方便地使用日志器,避免了重复声明,并确保日志器在程序启动时正确初始化,从而提升代码的可维护性和日志管理的便捷性。 …

    2026年5月10日
    000
  • GolangCookie与Session管理实践

    Golang通过net/http操作Cookie,结合Session实现用户状态管理;2. 推荐使用Redis存储Session,确保分布式环境一致性;3. 设置HttpOnly、Secure和SameSite属性增强安全性;4. 使用crypto/rand生成强随机Session ID并定期刷新有…

    2026年5月10日
    000

发表回复

登录后才能评论
关注微信