亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

springMVC + easyui + $.ajaxFileUpload實(shí)現(xiàn)文件上傳注意事項(xiàng)

 更新時(shí)間:2017年04月23日 10:59:14   作者:寒靈冰  
在使用easyUI做前端樣式展示時(shí),遇到了文件上傳的問(wèn)題,而且是在彈出層中提交表單,想做到不刷新頁(yè)面,所以選擇了使用ajaxFileUpload插件。下面通過(guò)本文給大家分享springMVC + easyui + $.ajaxFileUpload實(shí)現(xiàn)文件上傳注意事項(xiàng),需要的朋友參考下吧

在使用easyUI做前端樣式展示時(shí),遇到了文件上傳的問(wèn)題,而且是在彈出層中提交表單,想做到不刷新頁(yè)面,所以選擇了使用ajaxFileUpload插件。提交表單時(shí)一直發(fā)現(xiàn)后臺(tái)接收不到文件,后檢查發(fā)現(xiàn),原來(lái)是文件的id不對(duì)。

文件上傳框我們定義如下:

<input class="easyui-filebox" id="image" name="image" data-options="label:'產(chǎn)品圖片:',buttonText:'瀏覽',prompt:'僅支持jpg、gif、png等格式的圖片',required:true">

提交的方式如下:

$.ajaxFileUpload({
  type:'POST',
  url : '${pageContext.request.contextPath}/product/saveProduct',
  secureuri : false,
  data : queryFormParam('#formId'),//需要傳遞的數(shù)據(jù) json格式
  fileElementId :'image',
  dataType : 'json',
  success : function(data) { //上傳成功后的回調(diào)。
    if(data.status){
      $.messager.alert("提示","保存成功");
    }else {
      $.messager.alert("提示","保存失敗");
    }
  },
  error : function(data) {
    $.messager.alert("提示","異常,請(qǐng)稍后再試!");
  }
});

檢查后發(fā)現(xiàn),因easyui-filebox樣式使用時(shí),easyUI的js會(huì)為其創(chuàng)建一個(gè)type="file"的input,并且id也是easyUI定義的,自定義的id無(wú)效,可在easyUI的jquery.easyui.min.js中查看代碼如下:

(function($){
var _551=0;
function _552(_553){
var _554=$.data(_553,"filebox");
var opts=_554.options;
opts.fileboxId="filebox_file_id_"+(++_551);
$(_553).addClass("filebox-f").textbox(opts);
$(_553).textbox("textbox").attr("readonly","readonly");
_554.filebox=$(_553).next().addClass("filebox");
var file=_555(_553);
var btn=$(_553).filebox("button");
if(btn.length){
$("<label class=\"filebox-label\" for=\""+opts.fileboxId+"\"></label>").appendTo(btn);
if(btn.linkbutton("options").disabled){
file.attr("disabled","disabled");
}else{
file.removeAttr("disabled");
}
}
};
function _555(_556){
var _557=$.data(_556,"filebox");
var opts=_557.options;
_557.filebox.find(".textbox-value").remove();
opts.oldValue="";
var file=$("<input type=\"file\" class=\"textbox-value\">").appendTo(_557.filebox);
file.attr("id",opts.fileboxId).attr("name",$(_556).attr("textboxName")||"");
file.attr("accept",opts.accept);
if(opts.multiple){
file.attr("multiple","multiple");
}
file.change(function(){
var _558=this.value;
if(this.files){
_558=$.map(this.files,function(file){
return file.name;
}).join(opts.separator);
}
$(_556).filebox("setText",_558);
opts.onChange.call(_556,_558,opts.oldValue);
opts.oldValue=_558;
});
return file;
};

表單中可以定義多個(gè)filebox,并且filebox的id為filebox_file_id_+序號(hào),如果只有一個(gè),那就是filebox_file_id_1,因我這邊只有一個(gè),然后將ajaxFileUpload提交時(shí)的fileElementId 改成‘filebox_file_id_1',后臺(tái)就接收到image值了。

這個(gè)是看源碼知道的,如果不看源碼,其實(shí)可以直接用jQuery的方式獲得id,如下:

var image_id= $("input[name='image']").attr("id");

因image名字在我的表單中是唯一的,所以通過(guò)名字來(lái)獲得id,然后將id填入ajaxFileUpload的fileElementId 中即可達(dá)到同樣的效果。

springMVC后臺(tái)采用的是CommonsMultipartFile來(lái)接收文件,如下,得到路徑后,用image.transferTo(saveDir);保存即可。

@RequestParam("image") CommonsMultipartFile image

以上所述是小編給大家介紹的springMVC + easyui + $.ajaxFileUpload實(shí)現(xiàn)文件上傳注意事項(xiàng),希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!

相關(guān)文章

最新評(píng)論