嗨,任何人都可以告诉我如何使用ajax,jquery和Struts2上传文件。我已经浏览了网上的很多教程,但是我没有得到任何可能的解决方案。要求是当我们点击按钮时,需要调用javascript函数.javascript(jquery)启动Ajax引擎,并且ajax需要调用struts动作来获取响应。这里的请求和响应不刷新页面,也不使用IFrame。上传文件使用Ajax,Jquery和Struts2
0
A
回答
0
我使用iframe在不刷新的情况下提交数据。
i)我的html如下:
1)添加表单标签。 //你可以复制粘贴我的表单标签只是改变了行动
2)添加目标=“my_iframe” // iframe的名字..它可以是任何东西
<div class="bp_up_input">
<form name="banner_image_uploads" id="banner_image_uploads" method="post" action="" target="my_iframe" enctype="multipart/form-data">
<span>
<input type="file" name="banner_image" class="my_vld" lang="Image_path" />
<input type="button" id="banner_image_upload" value="Upload" class="bp_button_style" />
</span>
<input type="hidden" name="slt_store_id" value="" />
<input type="hidden" name="sld_location" value="" />
</form>
</div>
二)我的JavaScript代码一个如下:
$('#banner_image_upload').live('click',function(){
if($.trim($('input[name="banner_image"]').val()) != '' && $.trim($('select[name="bp_location"]').val()) != '' && $.trim($('#store_names').val()) != ''){
$("iframe").remove(); //Remove previous iframe if present
$("body").append('<iframe id="my_iframe" name="my_iframe" src="" style="display:none;"></iframe>'); //Append iframe to body with id my_iframe
$('#banner_image_uploads').submit();//submit the form with id banner_image_uploads
$("#my_iframe").load(function(){
var val = $("iframe")[0].contentDocument.body.innerHTML; // I use php so I just echo the response which I want to send e.g 250:new and save it in var val.
var data = val.split(':'); // I split the variable by :
var html = '<tr><td><img width="800" height="60" border="0" src="/assets/store_banners/live/'+$.trim($('input[name="sld_location"]').val())+'/'+data[1]+'" id="'+data[0]+'"><a href="#nodo"><img src="/images/delete_trash.png" width="9" height="12" class="image_delete" style="padding-left:37%;"/></a></td></tr>'; // In my case I wanted to upload an image so on success I had to show the image which was uploaded. You can skip this and the below code if you want.
$('.bp_table tbody').append(html); //Append the uploaded image to the container I wanted.
$('input[name="banner_image"]').val(''); //On success I clear the file name
});
}else{
alert('Please Select filters');
}
+0
Can你请告诉我不使用iframe,如何使用jquery和ajax解决这个问题。 –
0
嗨下面的代码是为我工作。我希望它能帮助你。
JSP代码:
<div id="uploadImg">
<s:form id="uploadImgForm" action="strutsaction" method="post" enctype="multipart/form-data">
<s:file name="imgFileUpload" label="Choose file to upload" accept="image/*"></s:file>
<s:submit value="Upload" align="center" id="uploadImgSubmitBtn"></s:submit>
</s:form>
<div>
JQuery的:
$("#uploadImgSubmitBtn").click(function(e){
// Get form
var form = $('#uploadImgForm')[0];
// Create an FormData object
var data = new FormData(form);
$.ajax({
type: "POST",
enctype: 'multipart/form-data',
url: "strutsaction.action",
data : data,
cache: false,
processData: false,
contentType: false,
success: function(data){
$('#uploadImg').html(data);
}
});
});
相关问题
- 1. 使用jQuery Ajax和PHP上传文件
- 2. 使用jQuery和Ajax上传文件
- 3. 文件上传和使用Struts2的
- 4. 用jQuery AJAX和FormData上传文件
- 5. Struts2文件上传
- 6. 使用ajax,jquery,php上传文件
- 7. 如何使用ajax上传jquery文件?
- 8. jQuery - 使用ajax的DataTables上传文件
- 9. 使用jQuery上传文件Ajax
- 10. 使用jQuery Ajax PhoneGap文件上传
- 11. 使用jquery ajax和FormData跟踪ajax文件上传的进度
- 12. Struts2-jquery插件的替代方案,用于使用Ajax在Struts2中上传文件
- 13. 如何使用ajax,jquery和spring mvc上传文件和数据
- 14. 上传文件和ajax/jquery失败
- 15. 上传jquery $ .ajax和php文件
- 16. jQuery的文件上传和Ajax
- 17. 使用Ajax和Apache CXF上传文件
- 18. 使用ajax和php上传文件
- 19. 使用AJAX和CFFILE上传文件
- 20. 使用AJAX和PHP上传文件
- 21. jQuery的AJAX文件上传
- 22. JQuery Ajax上传文件
- 23. codeigniter jquery ajax文件上传
- 24. 上传文件jQuery ajax MVC
- 25. Django ajax jquery文件上传
- 26. Jquery/Ajax文件上传
- 27. jQuery的AJAX文件上传
- 28. 的jQuery/AJAX - 文件上传
- 29. jquery Ajax PHP文件上传
- 30. 使用AJAX上传文件
您可以使用iframe来提交数据 –
感谢,不使用I帧是否有可能与jQuery和Ajax –
我一直使用iframe怎么把它方便快捷...还没有尝试过任何其他方法..您可以尝试下面的代码 –