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

jQuery 获取父元素属性时 undefined 的问题解决

聖光之護
发布: 2025-10-02 12:37:01
原创
575人浏览过

jquery 获取父元素属性时 undefined 的问题解决

本文针对在使用 jQuery 获取父元素属性时遇到 undefined 的问题,提供了一个清晰的解决方案。通过分析常见错误原因,结合代码示例,详细解释了如何正确地使用 closest() 和 find() 方法来获取目标元素的属性值,避免 undefined 错误的发生。

在使用 jQuery 进行 DOM 操作时,经常需要获取特定元素的属性值。当尝试获取父元素的属性,尤其是通过 closest() 和 find() 方法时,可能会遇到 undefined 的情况。这通常是由于选择器使用不当造成的。

问题分析

问题在于,jQuery 的选择器需要明确指定元素类型,例如类名、ID 或标签名。在原始代码中,closest('field') 和 find('field_info') 缺少了类名选择器所必需的 . 前缀。

解决方案

正确的做法是在选择器中添加 . 前缀,明确指定要查找的是类名为 field 和 field_info 的元素。修改后的代码如下:

AI建筑知识问答
AI建筑知识问答

用人工智能ChatGPT帮你解答所有建筑问题

AI建筑知识问答 22
查看详情 AI建筑知识问答
(function($){
    $.dispatcherFiles = {
        $filesDropzone: null,
        $parallelUploads: 100,
        $maxFiles: 10,
        $files: [],

        cacheDom: function(){
            this.$body = $('body');
        },

        functions: {
            uploadFiles: function (e) {
                // Corrected lines: Added '.' prefix to class selectors
                let field = $(e.currentTarget).closest('.field').find('.field_info');
                let photoID = $(e.currentTarget).closest('.field').find('.field_info').attr('data-field_photo_id');
                console.log(field);
                console.log(photoID);
            },
        },

        events: function(){
            this.$body.on('click', '.field .field_form .btnUpload', this.functions.uploadFiles.bind(this));
        },

        init: function () {
            this.cacheDom();
            this.events();
        }
    };

    $.dispatcherFiles.init();

})(jQuery);
登录后复制

代码解释:

  • $(e.currentTarget):获取触发 click 事件的元素,即点击的上传按钮。
  • .closest('.field'):从当前元素开始,向上查找最近的 class 为 field 的父元素。
  • .find('.field_info'):在找到的 field 元素内部,查找 class 为 field_info 的子元素。
  • .attr('data-field_photo_id'):获取 field_info 元素的 data-field_photo_id 属性值。

完整示例

以下是一个完整的 HTML 示例,展示了如何使用修改后的 jQuery 代码来正确获取 data-field_photo_id 属性:

<!DOCTYPE html>
<html>
<head>
    <title>jQuery Get Parent Attribute Example</title>
    <script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
    <link href="https://cdn.jsdelivr.net/npm/bootstrap@5.0.0/dist/css/bootstrap.min.css"  rel="stylesheet">
    <link href="http://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.3.0/css/font-awesome.css" rel="stylesheet">
    <style>
        .field {
            margin: 50px;
        }
    </style>
</head>
<body>

<div class="field">
    <label>Photos</label>
    <div class="field_info" data-field_photo_id="5">
        <div class="value" data-item_id=""></div>
    </div>
    <div class="field_form">
        <a class="btn btn-dark btn-md btnUpload" href="#">
            <i class="fa fa-cloud-upload"></i> Upload
        </a>
        <div id="dz_params_field_photo_5" data-type="pipeline" data-entity_id="11" style="display: none"></div>
        <div id="dz_field_photo_5_uploaded"></div>
    </div>
</div>

<div class="field">
    <label>Photos</label>
    <div class="field_info" data-field_photo_id="6">
        <div class="value" data-item_id=""></div>
    </div>
    <div class="field_form">
        <a class="btn btn-dark btn-md btnUpload" href="#">
            <i class="fa fa-cloud-upload"></i> Upload
        </a>
        <div id="dz_params_field_photo_6" data-type="pipeline" data-entity_id="12" style="display: none"></div>
        <div id="dz_field_photo_6_uploaded"></div>
    </div>
</div>

<div class="field">
    <label>Photos</label>
    <div class="field_info" data-field_photo_id="7">
        <div class="value" data-item_id=""></div>
    </div>
    <div class="field_form">
        <a class="btn btn-dark btn-md btnUpload" href="#">
            <i class="fa fa-cloud-upload"></i> Upload
        </a>
        <div id="dz_params_field_photo_7" data-type="pipeline" data-entity_id="13" style="display: none"></div>
        <div id="dz_field_photo_7_uploaded"></div>
    </div>
</div>

<script>
    (function($){
        $.dispatcherFiles = {
            $filesDropzone: null,
            $parallelUploads: 100,
            $maxFiles: 10,
            $files: [],

            cacheDom: function(){
                this.$body = $('body');
            },

            functions: {
                uploadFiles: function (e) {
                    let field = $(e.currentTarget).closest('.field').find('.field_info');
                    let photoID = $(e.currentTarget).closest('.field').find('.field_info').attr('data-field_photo_id');
                    console.log(field);
                    console.log(photoID);
                },
            },

            events: function(){
                this.$body.on('click', '.field .field_form .btnUpload', this.functions.uploadFiles.bind(this));
            },

            init: function () {
                this.cacheDom();
                this.events();
            }
        };

        $.dispatcherFiles.init();

    })(jQuery);
</script>

</body>
</html>
登录后复制

注意事项

  • 确保 jQuery 库已正确引入。
  • 检查 HTML 结构是否与 jQuery 选择器匹配。
  • 仔细检查选择器中的类名、ID 和标签名是否正确。
  • 使用开发者工具(如 Chrome DevTools)可以方便地调试 jQuery 代码,查看元素和属性值。

总结

当使用 jQuery 获取父元素属性时遇到 undefined,首先要检查选择器是否正确。确保在使用 closest() 和 find() 方法时,正确指定类名、ID 或标签名。通过添加 . 前缀来明确指定类名选择器,可以有效避免 undefined 错误的发生。

以上就是jQuery 获取父元素属性时 undefined 的问题解决的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源: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号