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'); //顯示重傳 } }); });
暫時就找到這樣解決,如你有更好方法,歡迎留言交流。