`

关于ajaxfileupload只能上传一次问题解决

阅读更多

出现问题:先上传了一次,后来发现读取完成以后,数据保存没有问题,当再次点击时,没有调用到,页面没什么反应

起初是怀疑页面缓存了,但是尝试在 input上添加了click,并设置了action的时间戳

$("#pictureInput").click(function(event){

   $("#pictureInput").attr("action","xxxx?"+event.timeStamp);

   alert($("#pictureInput").attr("action"));

 

});

 

但是上传完一次之后一样没有反应,并且点击也不走这个方法了,如果只是点击不上传,下次还可以进行点击。

 

说明问题还是出现在ajaxFileUpload.js中,

网上解决办法:在ajaxFileUpload.js源码中找到:createUploadForm 找到这一段

 

var oldElement = $('#' + fileElementId);    
  1. var newElement = $(oldElement).clone();    
  2. $(oldElement).attr('id', fileId);    
  3. $(oldElement).before(newElement);    
  4. $(oldElement).appendTo(form);   

改为:

 

var oldElement = $('#' + fileElementId);    
  1. var newElement = $(oldElement).clone(true);    
  2. //需要复制元素的所有事件处理。  
  3. $(oldElement).attr('id', fileId);    
  4. $(oldElement).before(newElement);    
  5. $(oldElement).appendTo(form);   

此处的  var newElement = $(oldElement).clone(true);    

clone() 方法生成被选元素的副本,包含子节点、文本和属性。

语法

$(selector).clone(includeEvents)
参数 描述
includeEvents

可选。布尔值。规定是否复制元素的所有事件处理。

默认地,副本中不包含事件处理器。

默认事件不进行处理,所以设置为true之后事件也进行了克隆。

 

问题解决

 

 

 

 

 

以下转自链接:http://my.oschina.net/u/2541538/blog/545574

bootstrap-wysiwyg整合ajaxFileUpload实现图片实时上传刷新

 

 

摘要
bootstrap-wysiwyg是一个十分精简已用的文本框插件,但是它有一个缺点,默认的插入图片并预览是用FileApi实现的,尽管它会将图片转化为字符串,但是存进数据库会十分庞大。本文尽量在不破坏bootstrap-wysiwyg原有架构的基础上对源码实施改写,达到实时上传的目的。

笔者最近由于项目需求,要实现一个前端文本编辑框,附带图片上传实时查看的功能。比较了网上的几款插件,首先是百度的UEitor,笔者发现该框架过于庞大,一个小框架引入如此多的文件并不是我想看到的;其次是jQuery的easyUI,虽然个人版的是免费的,但是项目属于公司业务,似乎用商业版的框架并不妥。考虑到笔者项目的前端主要就是在bootstrap的基础上构建起来的,我最终选用了bootstrap-wysiwyg插件,它非常的精简,轻巧而且扩展性强。

引入bootstrap-wysiwyg并且实现文本编辑功能十分的便捷,但是,我注意到,图片上传是用fileapi实现的。对于大多数网站,虽然用FileApi实现无上传预览用户体验非常好,但是真正存入数据库的时候,我们还是希望能够存储图片的在服务器的静态路径,而并非字符串化的图片。简而言之,我们需要对bootstrap-wysiwyg(以下简称WY)做稍许改写。

首先我们来观察下页面上图片控件,其它的控件略过,查一下源码,很容易发现如下代码:

<div class="btn-group">
	<a class="btn" title="Insert picture (or just drag & drop)" id="pictureBtn"><i class="icon-picture"></i></a>
        <input type="file" data-role="magic-overlay" 
            data-target="#pictureBtn"
	    data-edit="insertImage" />
</div>

做一下说明,data-role,data-target属性是bootstrap中预定义的事件,在这里我们可以理解为布局相关,不用考虑。关键点来了,第三个属性data-edit,bootstrap中并没有这一事件,观察bootstrap-wysiwyg.js,可以发现这样一些代码:

toolbar.find('input[type=file][data-' + options.commandRole + ']')
					.change( ...
					...
commandRole : 'edit',

也就是说,该属性其实是为了方便选择器而实现的,相当于给图片按钮添加了监听器事件。

我们接着研究一下WY图片预览的实现,第一步,就像上面代码展示的一样,监听器捕捉到fileInput的change事件,做出响应,调用insertFiles函数

restoreSelection();
if (this.type === 'file' && this.files && this.files.length > 0) {
	insertFiles(this.files);
}
saveSelection();
his.value = '';

找到insertFiles函数

insertFiles = function (files{
				editor.focus();
				$.each(files, function (idx, fileInfo{
					if (/^image\//.test(fileInfo.type)) {
						$.when(readFileIntoDataUrl(fileInfo)).done(function (dataUrl{
							execCommand('insertimage', dataUrl);
						}).fail(function (e{
							options.fileUploadError("file-reader", e);
						});
					} else {
						options.fileUploadError("unsupported-file-type", fileInfo.type);
					}
				});
			}

我们注意到它使用了jQuery的$.Deferred()方法,先调用了一个readFileIntoDataUrl方法,成功之后通过自封装的execCommand方法实现将图片输出到文本框。该图片其实就是一个<img>标签,只不过src属性是用字符串表示的图片。所以我们要做的其实是在监听器触发之后,将文件上传,获得图片的src,再把链接交给之后的execCommand方法。

由于笔者对Deferred并不是特别熟悉,所以还是采用更为通常的callback模式

观察ajaxFileUpload的调用方式:

$.ajaxFileUpload({
				url : ...,
				secureurl : false,
				fileElementId : ...,
				dataType : "json",
				success : function(obj) {
					...
				},
				error : function() {
					...
				}
			});

有两个必选的属性,url和fileElementId,为了保持依赖的正确性,重写ajaxFileUpload是不可取的。但是由于WY的控件是监听器实现的,所以通过函数将参数传过去是不现实的,所以我们需要自己对输入框定义一些属性来达到目的。

在fileInput中添加一些属性

<input type="file" id="pictureInput" name="picture"
					data-role="magic-overlay" data-target="#pictureBtn"
					data-edit="insertImage" action="..." />

id 用作 fileElementId,name属性也是必须的,主要是为了后台取值指名,action是图片需要提交到的url

在bootstrap-wysiwyg.js中定义一个函数名为uploadFileToServer,函数格式如下:

var uploadFileToServer = function(id, action, callback{
		$.ajaxFileUpload({
			url : action,
			secureurl : false,
			fileElementId : id,
			dataType : 'json',
			success : function(obj{
				if (obj.status) {
					callback(obj.imgsrc);
				} else
					options.fileUploadError("server-internal-exception",
							obj.message);
			},
			error : function({
				options.fileUploadErroe("upload-failure""");
			}
		});

将insertFiles方法作改写如下:

insertFiles = function(files, id, action) {
			editor.focus();
			$.each(files, function(idx, fileInfo) {
				if (/^image\//.test(fileInfo.type)) {
					/*
					 * $.when(readFileIntoDataUrl(fileInfo)).done(function(dataUrl) {
					 * execCommand('insertimage', dataUrl); }).fail(function(e) {
					 * options.fileUploadError("file-reader", e); });
					 */
					uploadFileToServer(id, action, function(src) {
						execCommand('insertimage', src);
					});
				} else {
					options.fileUploadError("unsupported-file-type",
							fileInfo.type);
				}
			});

同时对监听器做出一定的修改,以便拿到必要的属性

toolbar.find('input[type=file][data-' + options.commandRole + ']')
				.change(
					function() {
							restoreSelection();
								if (this.type === 'file' && this.files
										&& this.files.length > 0) {
									insertFiles(this.files, $(this).attr('id'),
											$(this).attr('action'));
								}
								saveSelection();
								this.value = '';
							});

主要是增加了两个参数位置。

如此,改写便完成了,注意,要确保正确执行,请在控件之前引用ajaxFileUpload.js

 

2016年1月14日 15:07:59更新:

今天在用的时候发现一个问题,即图片只能上传一次的问题,这是ajaxFileUpload.js的问题,解决方案:

ajaxfileupload.js原文第41行:

var newElement = jQuery(oldElement).clone();

改为:

var newElement = jQuery(oldElement).clone(true);

原因是ajaxFileUpload默认复制元素而不复制元素事件导致WY的监听器change失效。

另,附上$.Deferred对象的改写方法:

//原文第6行
var uploadFileToServer = function(id, action{
		var loader = $.Deferred();
		$.ajaxFileUpload({
			url : action,
			secureurl : false,
			fileElementId : id,
			dataType : 'json',
			success : function(json{
				if (json.status) {
					loader.resolve(json.imgsrc);
				} else {
					loader.reject('server-internal-exception', json.message);
				}
			},
			error : function({
				loader.reject('upload-failure''');
			}
		});
		return loader.promise();
	}
	
	//原文100行附近
	insertFiles = function(files, id, action{
			editor.focus();
			$.each(files,
					function(index, file{
						if (/^image\//.test(file.type)) {
							$.when(uploadFileToServer(id, action)).done(
									function(src{
										execCommand('insertimage', src);
									}).fail(function(e, message{
								options.fileUploadError(e, message);
							});
						} else {
							options.fileUploadError("unsupported-file-type",
									file.type);
						}
					});

 

分享到:
评论

相关推荐

    解决使用ajaxFileUpload上传控件出现的问题:回调函数总是进入error或success

    为了调试和解决问题,你可以使用浏览器的开发者工具,查看网络请求的详细信息,包括请求头、请求体、响应头和响应体,这样可以快速定位问题。同时,也可以在代码中添加日志输出,以跟踪执行流程和变量状态。 总的来...

    关于ajaxfileupload 文件上传实例

    在Web开发中,文件上传是一项常见的功能,AjaxFileUpload是一个基于JavaScript和AJAX技术的文件上传组件,它允许用户在不刷新页面的情况下实现异步文件上传。本实例将重点讲解如何在Spring MVC框架下利用...

    解决ajaxfileupload.js在IE9,firefox下文件超大无效

    本文将详细介绍如何解决在IE9和Firefox下使用`AjaxFileUpload.js`进行文件上传时遇到的大文件上传失效的问题。 #### 问题描述 当尝试通过`AjaxFileUpload.js`上传较大文件至服务器时,在IE9和Firefox浏览器中可能...

    ajaxfileupload文件上传js

    通过ajaxfileupload实现JS的文件上传

    ajaxfileupload

    为了解决这个问题,`ajaxFileUpload`应运而生,这是一个基于jQuery的异步文件上传插件。它允许用户在不刷新页面的情况下实现文件的上传,提高了交互性和用户体验。 ### 一、异步上传的优势 1. **无需页面刷新**:...

    AjaxFileUpload

    4. **JavaScript/jQuery插件**:AjaxFileUpload是一个jQuery插件,它扩展了jQuery的功能,为文件上传提供了一个方便的接口。 5. **CSS样式表**:`ajaxfileupload.css`包含定义上传组件外观的CSS样式,如按钮样式、...

    ajaxFileUpload上传图片预览总结

    **AjaxFileUpload上传图片预览技术详解** 在Web开发中,用户经常需要上传图片,而实时预览功能能显著提升用户体验。AjaxFileUpload是一个JavaScript组件,它允许我们实现异步文件上传并提供预览功能,无需刷新页面...

    解决ajaxfileupload中ie9、ie10兼容的问题

    这里解决了ajaxfileupload中ie9、ie10兼容的问题,下载下来直接可以使用

    AjaxFileUpload 文件上传

    AjaxFileUpload 是一个专门用于实现异步文件上传的JavaScript组件,它利用了Ajax技术,让用户可以在不刷新页面的情况下完成文件上传,提供了更为流畅和友好的用户体验。 AjaxFileUpload 的核心原理在于利用Ajax...

    $.ajaxFileUpload 文件上传

    在IT行业中,文件上传是网页应用中常见的功能之一,尤其是对于处理大文件或者批量上传时,需要高效且用户友好的解决方案。$.ajaxFileUpload 是一个jQuery插件,它提供了异步文件上传的能力,使得用户无需刷新页面...

    ajaxfileupload多文件上传

    **AjaxFileUpload是基于JavaScript和Ajax技术的一种文件上传组件,它允许用户在不刷新整个页面的情况下实现异步文件上传。这种技术在Web开发中被广泛应用,因为它提供了良好的用户体验,允许用户在后台处理文件上传...

    JSP使用ajaxFileUpload.js实现跨域问题.docx

    ### JSP 使用 ajaxFileUpload.js 实现跨域问题解析 #### 一、背景与概述 在Web开发中,跨域问题一直...此外,调试过程中利用好各种工具也是解决问题的关键。希望这篇文章能够帮助开发者们更好地理解和解决跨域问题。

    文件上传 ajaxfileupload.zip

    标题中的“文件上传 ajaxfileupload.zip”提示我们这个压缩包可能包含了一个用于实现文件上传功能的JavaScript库,名为“ajaxfileupload.js”。在Web开发中,文件上传是常见且重要的功能,尤其在需要用户提交图片、...

    使用ajaxFileUpload实现图片上传

    `ajaxFileUpload`是一个JavaScript插件,它允许开发者利用Ajax技术实现异步文件上传,特别是图片上传,无需刷新整个页面。这种方法提高了用户体验,因为它可以在后台处理上传过程,保持页面的实时性和流畅性。 `...

    完美SS2H+ajaxfileupload异步上传多个附件、删除

    标题中的“完美SS2H+ajaxfileupload异步上传多个附件、删除”涉及到的是一个Web应用中的文件上传功能实现,具体来说,它结合了Spring Security(SS)和Struts2 (SH)两个框架,并利用ajaxfileupload.js这个JavaScript...

    ajax上传图片之ajaxfileupload

    总的来说,AjaxFileUpload.js库提供了一种便捷的方式来处理图片的异步上传,同时通过优化`handleError`函数和处理浏览器兼容性问题,确保了上传功能的稳定性和可用性。在实际项目中,开发者应当根据具体需求对库进行...

    Ajaxfileupload.js 异步上传图片

    ajaxfileupload.js 这是个非常好的异步上传图片的插件,来解决form表单上传时要刷新页面的问题。

    ajaxfileupload1.0.zip 文件无刷新上传代码

    这个压缩包“ajaxfileupload1.0.zip”提供了一种实现无刷新文件上传的解决方案。无刷新上传,也称为异步文件上传,是现代网页应用中常用的一个功能,它允许用户在不重新加载整个页面的情况下发送文件到服务器。这种...

Global site tag (gtag.js) - Google Analytics