0

0

获取模态窗口关联元素的Data属性:一个Dropzone文件上传的实用教程

心靈之曲

心靈之曲

发布时间:2025-09-24 21:01:27

|

828人浏览过

|

来源于php中文网

原创

获取模态窗口关联元素的data属性:一个dropzone文件上传的实用教程

本教程旨在解决在Bootstrap模态窗口中使用Dropzone.js进行文件上传时,如何获取触发模态窗口的元素上的data-*属性值的问题。我们将探讨如何通过事件委托和$(this)来准确获取所需的数据,并提供完整的代码示例,帮助开发者轻松实现文件上传功能。

在开发Web应用时,经常需要在模态窗口中执行一些操作,例如文件上传。如果需要根据触发模态窗口的元素来动态配置模态窗口的行为,就需要获取该元素上的data-*属性。本教程将以一个使用Dropzone.js进行文件上传的场景为例,详细介绍如何获取触发模态窗口的按钮上的data-action_url属性。

问题背景

假设我们有一个页面,其中包含多个文件上传区域,每个区域都有一个上传按钮,点击按钮会弹出一个模态窗口,用于上传文件。每个上传按钮都关联着一个dz_params_item元素,该元素包含data-action_url属性,用于指定Dropzone.js上传文件的URL。

我们的目标是在模态窗口打开时,获取点击的上传按钮所关联的data-action_url属性,并将其传递给Dropzone.js,以便Dropzone.js能够将文件上传到正确的URL。

解决方案

为了解决这个问题,我们需要使用事件委托和$(this)来获取触发模态窗口的元素。

Glimmer Ai
Glimmer Ai

基于GPT-3和DALL·E2的PPT制作工具

下载
  1. 事件委托: 将事件监听器绑定到body元素上,然后使用选择器来过滤事件目标。这样,即使动态添加的元素也能触发事件。
  2. $(this): 在事件处理函数中,$(this)指向触发事件的元素,也就是点击的上传按钮。

以下是修改后的代码:

(function($){
    let $modalId = '#modal-upload';
    let $filesDropzone = null;
    let $parallelUploads = 100;
    let $maxFiles = 10;
    let $files = [];


    $.dispatcherFiles = {

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

        functions: {
            uploadFilesModal: function (e) {
                // 使用 $(this) 获取点击的按钮元素
                let $uploadButton = $(e.currentTarget);

                // 找到与按钮关联的 .field_form 元素,然后找到 .dz_params_item 元素
                let $dropzoneParamEl = $uploadButton.closest('.field_form').find('.dz_params_item');

                // 从 .dz_params_item 元素获取 data-action_url 属性
                let action_url = $dropzoneParamEl.attr('data-action_url');

                console.log($dropzoneParamEl);
                console.log(action_url);

                // 打开模态窗口
                $($modalId).modal('toggle');

                // 初始化 Dropzone.js
                $($modalId + ' #filesDropzone').addClass('dropzone');

                $filesDropzone = new Dropzone($modalId + ' .dropzone', {
                    url: action_url,
                    uploadMultiple: true,
                    parallelUploads: $parallelUploads,
                    maxFiles: $maxFiles,
                });

                $filesDropzone.on('error', function() {
                    $($modalId).modal('hide');
                    alert('error');
                });

                $filesDropzone.on('success', function(file, response) {
                    $($modalId).modal('hide');
                });
            },
        },

        events: function(){
            // 使用事件委托,将事件监听器绑定到 body 元素上
            this.$body.on('click', '.btnUpload', this.functions.uploadFilesModal.bind(this));
        },

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

    $.dispatcherFiles.init();

})(jQuery);

代码解释:

  • this.$body.on('click', '.btnUpload', this.functions.uploadFilesModal.bind(this));:这行代码使用事件委托,将click事件监听器绑定到body元素上,并指定选择器为.btnUpload。这意味着,当点击任何具有.btnUpload类的元素时,都会触发uploadFilesModal函数。
  • let $uploadButton = $(e.currentTarget);:在uploadFilesModal函数中,e.currentTarget指向触发事件的元素,也就是点击的上传按钮。我们将其包装成jQuery对象,以便后续操作。
  • let $dropzoneParamEl = $uploadButton.closest('.field_form').find('.dz_params_item');:这行代码首先使用closest('.field_form')找到上传按钮最近的.field_form父元素,然后使用find('.dz_params_item')找到该父元素下的.dz_params_item子元素。
  • let action_url = $dropzoneParamEl.attr('data-action_url');:这行代码从.dz_params_item元素中获取data-action_url属性的值。

完整示例代码

<!DOCTYPE html>
<html>
<head>
    <title>Dropzone File Upload</title>
    <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/bootstrap/5.3.0/css/bootstrap.min.css">
    <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.3.0/css/font-awesome.css">
    <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/dropzone/5.9.3/dropzone.min.css" integrity="sha512-jU/7UFiaW5uWm5Wnq9jPQeMBpjxWsi9mRROCBwalkDzRCwnhXY0UuyBmJlgu6PpyzCnpI0e0UqkCU9IoFGnhvg==" crossorigin="anonymous" referrerpolicy="no-referrer" />
    <style>
        .field {
            margin: 50px;
        }
    </style>
</head>
<body>

<div class="form-group">
    <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" data-toggle="modal" href="#" data-target="#modal-upload">
                <i class="fa fa-cloud-upload"></i> Upload
            </a>
            <div class="dz_params_item"
                 data-entity_id="1"
                 data-action_url="/files/upload/1"></div>
        </div>
    </div>
</div>

<div class="form-group">
    <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" data-toggle="modal" href="#" data-target="#modal-upload">
                <i class="fa fa-cloud-upload"></i> Upload
            </a>
            <div class="dz_params_item"
                 data-entity_id="2"
                 data-action_url="/files/upload/2"></div>
        </div>
    </div>
</div>

<div class="form-group">
    <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" data-toggle="modal" href="#" data-target="#modal-upload">
                <i class="fa fa-cloud-upload"></i> Upload
            </a>
            <div class="dz_params_item"
                 data-entity_id="3"
                 data-action_url="/files/upload/3"></div>
        </div>
    </div>
</div>

<div class="modal fade" id="modal-upload" tabindex="-1" role="dialog" aria-hidden="true">
    <div class="modal-dialog modal-dialog-centered" role="document">
        <div class="modal-content">
            <div class="modal-header">
                <h4 class="modal-title">
                    Upload files
                </h4>
                <button type="button" class="close" data-dismiss="modal" aria-label="Close">
                    <span aria-hidden="true"><i class="fal fa-times"></i></span>
                </button>
            </div>
            <div class="modal-body">
                <div id="filesDropzone"></div>
            </div>
        </div>
    </div>
</div>

<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/bootstrap/5.3.0/js/bootstrap.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/dropzone/5.9.3/dropzone.min.js" integrity="sha512-U2WE1ktpMTuRBPoCFDzomoIorbOyUv0sP8B+INA3EzNAhehbzED1rOJg6bCqPf/Tuposxb5ja/MAUnC8THSbLQ==" crossorigin="anonymous" referrerpolicy="no-referrer"></script>

<script>
    (function($){
        let $modalId = '#modal-upload';
        let $filesDropzone = null;
        let $parallelUploads = 100;
        let $maxFiles = 10;
        let $files = [];


        $.dispatcherFiles = {

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

            functions: {
                uploadFilesModal: function (e) {
                    // 使用 $(this) 获取点击的按钮元素
                    let $uploadButton = $(e.currentTarget);

                    // 找到与按钮关联的 .field_form 元素,然后找到 .dz_params_item 元素
                    let $dropzoneParamEl = $uploadButton.closest('.field_form').find('.dz_params_item');

                    // 从 .dz_params_item 元素获取 data-action_url 属性
                    let action_url = $dropzoneParamEl.attr('data-action_url');

                    console.log($dropzoneParamEl);
                    console.log(action_url);

                    // 打开模态窗口
                    $($modalId).modal('toggle');

                    // 初始化 Dropzone.js
                    $($modalId + ' #filesDropzone').addClass('dropzone');

                    $filesDropzone = new Dropzone($modalId + ' .dropzone', {
                        url: action_url,
                        uploadMultiple: true,
                        parallelUploads: $parallelUploads,
                        maxFiles: $maxFiles,
                    });

                    $filesDropzone.on('error', function() {
                        $($modalId).modal('hide');
                        alert('error');
                    });

                    $filesDropzone.on('success', function(file, response) {
                        $($modalId).modal('hide');
                    });
                },
            },

            events: function(){
                // 使用事件委托,将事件监听器绑定到 body 元素上
                this.$body.on('click', '.btnUpload', this.functions.uploadFilesModal.bind(this));
            },

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

        $.dispatcherFiles.init();

    })(jQuery);
</script>

</body>
</html>

注意事项:

  • 确保在引入Dropzone.js之前引入jQuery和Bootstrap.js。
  • 根据实际情况修改$modalId、$parallelUploads和$maxFiles等变量的值。
  • 在服务器端处理文件上传逻辑。

总结

通过使用事件委托和$(this),我们可以轻松地获取触发模态窗口的元素上的data-*属性,并将其用于动态配置模态窗口的行为。本教程提供了一个完整的代码示例,帮助开发者快速实现基于Dropzone.js的文件上传功能。这种方法可以应用于各种需要根据触发元素动态配置模态窗口的场景,提高了代码的灵活性和可维护性。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
jquery插件有哪些
jquery插件有哪些

jquery插件有jQuery UI、jQuery Validate、jQuery DataTables、jQuery Slick、jQuery LazyLoad、jQuery Countdown、jQuery Lightbox、jQuery FullCalendar、jQuery Chosen和jQuery EasyUI等。本专题为大家提供jquery插件相关的文章、下载、课程内容,供大家免费下载体验。

156

2023.09.12

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

337

2023.10.13

jquery删除元素的方法
jquery删除元素的方法

jquery可以通过.remove() 方法、 .detach() 方法、.empty() 方法、.unwrap() 方法、.replaceWith() 方法、.html('') 方法和.hide() 方法来删除元素。更多关于jquery相关的问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

406

2023.11.10

jQuery hover()方法的使用
jQuery hover()方法的使用

hover()是jQuery中一个常用的方法,它用于绑定两个事件处理函数,这两个函数将在鼠标指针进入和离开匹配的元素时执行。想了解更多hover()的相关内容,可以阅读本专题下面的文章。

515

2023.12.04

jquery实现分页方法
jquery实现分页方法

在jQuery中实现分页可以使用插件或者自定义实现。想了解更多jquery分页的相关内容,可以阅读本专题下面的文章。

312

2023.12.06

jquery中隐藏元素是什么
jquery中隐藏元素是什么

jquery中隐藏元素是非常重要的一个概念,在使用jquery隐藏元素之前,需要先了解css样式中关于元素隐藏的属性,比如display、visibility、opacity等属性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

128

2024.02.23

jquery中什么是高亮显示
jquery中什么是高亮显示

jquery中高亮显示是指对页面搜索关键词时进行高亮显示,其实现办法:1、先获取要高亮显示的行,获取搜索的内容,再遍历整行内容,最后添加高亮颜色;2、使用“jquery highlight”高亮插件。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

183

2024.02.23

jQuery 正则表达式相关教程
jQuery 正则表达式相关教程

本专题整合了jQuery正则表达式相关教程大全,阅读专题下面的文章了解更多详细内容。

51

2026.01.13

TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

26

2026.03.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Sass 教程
Sass 教程

共14课时 | 0.9万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.6万人学习

CSS教程
CSS教程

共754课时 | 43万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

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