使用plupload自定義參數(shù)實現(xiàn)多文件上傳
1、在開發(fā)中可能需要用戶附件上傳的功能,實現(xiàn)批量上傳功能其實就將多個上傳任務(wù)放到一個集合中,分別上傳。
2,使用plupload js插件可以很輕松的實現(xiàn)帶參數(shù)的多文件上傳

3、具體js實現(xiàn)方式
<script type="text/javascript">
var map={};//文件id為key,文件類型為value的集合
// Custom example logic
var uploader = new plupload.Uploader({
runtimes : 'html5,flash,silverlight,html4',
browse_button : 'pickfiles', // you can pass in id...
container : document.getElementById('container'), // ... or DOM Element itself
url : '../action/photoUpload.jsp',
flash_swf_url : '../../js/Moxie.swf',
silverlight_xap_url : '../../js/Moxie.xap',
filters : {
max_file_size : '5mb',
mime_types : [ {
title : "圖片類型",
extensions : "jpg,gif,png"
} ]
},
init : {
PostInit : function() {
document.getElementById('uploadfiles').onclick = function() {
uploader.start();
return false;
};
},
BeforeUpload:function(up,file){
//重點在這里,上傳的時候自定義參數(shù)信息
uploader.setOption("multipart_params",{"apptype":${param.type},"id":${param.id},"fileType":map[file.id]});
},
FileUploaded:function(up,file){
$("#"+file.id+"btn").parent().html("上傳完畢");
$("#"+file.id+"btn").remove();
},
FilesAdded : function(up, files) {
if($("#fileType").val()==1){
alert("請選擇附件類型!");
//清空剛才選擇的文件
plupload.each(files,function(file) {
uploader.removeFile(file.id);
});
return false;
}
plupload.each(files,function(file) {
map[file.id]=$("#fileType").val();
$("#uploadTable").append("<tr id='"+file.id+"tr'><td>"+$("#fileType").val()+"</td><td>"+file.name+"</td><td><button type='button' id='"+file.id+"btn' onclick=del('"+file.id+"')>刪除</button> </td><td id='"+file.id+"_progress'></td></tr>");
});
},
UploadProgress : function(up, file) {
$("#"+file.id+"_progress").html('<span>'+ file.percent + "%</span>");
},
Error : function(up, err) {
alert("此文件上傳失敗!");
}
}
});
uploader.init();
//根據(jù)文件id刪除此文件,并且在table中刪除此文件的信息
function del(id){
uploader.removeFile(id);
$("#"+id+"tr").remove();
map[id]="";
}
</script>
其他參數(shù)在其官網(wǎng)上:http://www.plupload.com/
宅男程序猿,文采不行,如果看著累直接復(fù)制js,注意頁面上需要有:
<div id="filelist"></div> <div id="container"> <center> 提示:必須上傳 "商戶營業(yè)執(zhí)照","稅務(wù)登記證明","企業(yè)法人身份證","考察照片","商戶信息調(diào)查表","商戶協(xié)議" 才能提交審批! </center> <label>附件類型:</label> <select name="fileType" id="fileType" > <option value="1">-------請選擇-----</option> <option value="商戶營業(yè)執(zhí)照">商戶營業(yè)執(zhí)照</option> <option value="稅務(wù)登記證明">稅務(wù)登記證明</option> <option value="商戶信息變更表">商戶信息變更表</option> <option value="其他">其他</option> </select> <button class="button" id="pickfiles">選擇文件</button> <button class="button" id="uploadfiles">批量上傳</button> <button class="button" onclick="window.location.reload()">刷新</button> <button class="button" onclick="window.close()">關(guān)閉窗口</button> <table style="width: 600px" id="uploadTable" border="1"> <tr> <td>文件類型</td> <td>文件名稱</td> <td>操作</td> <td>上傳進(jìn)度</td> </tr> </table> </div>
以上所述是小編給大家介紹的使用plupload自定義參數(shù)實現(xiàn)多文件上傳,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關(guān)文章
JavaScript實現(xiàn)的多種鼠標(biāo)拖放效果
這篇文章主要介紹了JavaScript實現(xiàn)的多種鼠標(biāo)拖放效果,涉及JavaScript響應(yīng)鼠標(biāo)事件動態(tài)變換頁面元素屬性的相關(guān)技巧,具有一定參考借鑒價值,需要的朋友可以參考下2015-11-11
使用JavaScript實現(xiàn)一個交互式音樂播放器
JavaScript,作為前端開發(fā)的重要語言,可以實現(xiàn)許多復(fù)雜的功能,在這篇文章中,我們將一起創(chuàng)建一個交互式的音樂播放器,快跟隨小編一起學(xué)習(xí)一下吧2024-01-01
JavaScript設(shè)計模式之單例模式原理與用法實例分析
這篇文章主要介紹了JavaScript設(shè)計模式之單例模式原理與用法,結(jié)合實例形式分析了單例模式的原理、命名空間的使用、閉包、惰性單例形式以及單例模式的基本應(yīng)用,需要的朋友可以參考下2018-07-07

