Layui upload多图片上传, 传参后台接受不到

Layui upload动态传参,后台接收不到,解决方法

这里参数动态($(#).val())拿去不到,除非写死,必须要用before从新赋值
 layui.config({
        base: ‘/Assets/layui/‘ //静态资源所在路径
    }).extend({
        index: ‘lib/index‘ //主入口模块
    }).use([‘index‘, ‘upload‘], function () {
        var $ = layui.jquery
            , upload = layui.upload;

        var Title;
        var KeyWork;
        var Description;
        var PicImage_Id;

        //多文件列表示例
        var demoListView = $(‘#test-upload-demoList‘)
            , uploadListIns = upload.render({
                elem: ‘#test-upload-testList‘
                , url: ‘/FileUpload‘
                , data: { PicImage_Id:$("#Id").val(),Title: Title, KeyWork: KeyWork,Description:Description }    //额外传输的参数, 这里参数动态($(#).val())拿去不到,除非写死,必须要用before从新赋值
                , accept: ‘file‘
                , multiple: true
                , auto: false
                , bindAction: ‘#test-upload-testListAction‘
                , choose: function (obj) {
                    var files = this.files = obj.pushFile(); //将每次选择的文件追加到文件队列
                    //读取本地文件
                    obj.preview(function (index, file, result) {
                        var tr = $([‘<tr id="upload-‘ + index + ‘">‘
                            , ‘<td>‘ + file.name + ‘</td>‘
                            , ‘<td>‘ + (file.size / 1014).toFixed(1) + ‘kb</td>‘
                            , ‘<td>等待上传</td>‘
                            , ‘<td>‘
                            , ‘<button class="layui-btn layui-btn-mini test-upload-demo-reload layui-hide">重传</button>‘
                            , ‘<button class="layui-btn layui-btn-mini layui-btn-danger test-upload-demo-delete">删除</button>‘
                            , ‘</td>‘
                            , ‘</tr>‘].join(‘‘));

                        //单个重传
                        tr.find(‘.test-upload-demo-reload‘).on(‘click‘, function () {
                            obj.upload(index, file);
                        });

                        //删除
                        tr.find(‘.test-upload-demo-delete‘).on(‘click‘, function () {
                            delete files[index]; //删除对应的文件
                            tr.remove();
                            uploadListIns.config.elem.next()[0].value = ‘‘; //清空 input file 值,以免删除后出现同名文件不可选
                        });

                        demoListView.append(tr);
                    });
                }, before: function (obj) {
                    this.data.Title = $("#Title").val();
                    this.data.KeyWork = $("#KeyWork").val();
                    this.data.Description = $("#Description").val();

                }
                , done: function (res, index, upload) {
                    debugger;
                    if (res.code == 200) { //上传成功
                        var tr = demoListView.find(‘tr#upload-‘ + index),
                            tds = tr.children();
                        tds.eq(2).html(‘<span style="color: #5FB878;">上传成功</span>‘);
                        tds.eq(3).html(‘‘); //清空操作
                        return delete this.files[index]; //删除文件队列已经上传成功的文件
                    }
                    this.error(index, upload);
                }
                , error: function (index, upload) {
                    debugger;
                    var tr = demoListView.find(‘tr#upload-‘ + index)
                        , tds = tr.children();
                    tds.eq(2).html(‘<span style="color: #FF5722;">上传失败</span>‘);
                    tds.eq(3).find(‘.test-upload-demo-reload‘).removeClass(‘layui-hide‘); //显示重传
                }
            });
    });

暂时就找到这样解决,如你有更好方法,欢迎留言交流。

原文地址:https://www.cnblogs.com/youmingkuang/p/12294800.html

时间: 2024-09-29 20:42:28

Layui upload多图片上传, 传参后台接受不到的相关文章

layui加tp5图片上传实例

<div class="layui-fluid"> <div class="layui-row"> <form class="layui-form"> <div class="layui-form-item"> <label for="username" class="layui-form-label"> <span cl

关于vue-element-admin的采坑记录-upload组件图片上传问题

个人博客里部分内容用到了图片上传 那就需要用到vue-element-admin中的upload组件 首先我们需要在需要到图片上传的vue文件里引入upload组件 并使用标签的形式使用该组件 通过v-model绑定image属性 <template> <div class="createPost-container"> <Upload v-model="image"/> </div> </template>

多文件上传以及java后台接受

最近项目用到的,实现多文件以及一些信息上传, 以及后台接收及读取用到了spring及springmvc相关框架. 不多说废话,直接上例子(这有关键代码) 首先,前台页面 <form action="/uploader/upload/uploadFiles" method="post" enctype="multipart/form-data"> <input type="file"size="30&

饿了么Element UI之Upload组件图片上传【原创】

图片文件换汤不换药,只要注意前端的写法即可 1.饿了么组件可以利用 http-request 的属性对上传进行自定义 :http-request="uploadFile" 2.设置文件FormData对象传入请求 const formdata = new FormData(); const file = params.file; formdata.append("file", file); 3.全部代码 <template> <div style=

SSM中前台传数组。后台接受的问题

当时写得时候,忘记考虑json的jar,做个记录. 第一步:先带入jar <dependency> <groupId>com.fasterxml.jackson.core</groupId> <artifactId>jackson-core</artifactId> <version>2.9.8</version> </dependency> <dependency> <groupId>

layui图片上传

<!DOCTYPE html><html><head> <title>layui图片上传</title> <script type="text/javascript" src="./jquery11.js"></script> <script type="text/javascript" src="./layui/layui.js">

bootstrap-fileinput 图片上传

bootstrap-fileinput 源文件 在网上下载 CSS: <link href="../../static/Bootstrap/css/plugins/bootstrap-fileinput/fileinput.min.css" rel="stylesheet" /> JS: <script src="../../static/Bootstrap/js/plugins/bootstrap-fileinput/fileinput

summernote 图片上传

<script type="text/javascript"> $(document).ready(function () { function sendFile(file, editor, $editable) { var formData = new FormData(); formData.append('file', file); // XMLHttpRequest 对象 var xhr = new XMLHttpRequest(); xhr.open("

layui 图片上传+表单提交+ Spring MVC

Layui 的上传是最常用的, 不可或缺, 记录一下代码, 以后复制都能用!! 1.前端HTML: <div class="layui-form-item"> <label class="layui-form-label">修改头像</label> <div class="layui-input-inline uploadHeadImage"> <div class="layui-u