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'); //顯示重傳
                }
            });
    });

 暫時就找到這樣解決,如你有更好方法,歡迎留言交流。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM