jquery.uploadify上传经常会碰到的问题
2012-04-21 16:18
441 查看
1. buttonText 属性设置中文无效的问题
原因:uploadify.js 中对使用escape()进行编码,在uploadify.swf中使用unescape()进行解码,js中的escape()方法是采用ISO Latin字符集对指定的字符串进行编码的,很明显咱们的中文,包括日文,韩文(CJK)都不包括在ISO Latin字符集里面的。
解决方法:
A. 修改插件
修改uploadify.js
将 if (settings.buttonText) data.buttonText = escape(settings.buttonText);
改为 if (settings.buttonText) data.buttonText = encodeURI(settings.buttonText);
修改uploadify.fla
将 browseBtn.empty.buttonText.text = unescape(param.buttonText);
改为 browseBtn.empty.buttonText.text = decodeURI(param.buttonText);
然后重新生成uploadify.swf并拷入项目中
B. 使用 buttonImg 参数
显然buttonImg是用来设置图片按钮的,自己做的图片,没编码当然不会乱码了,不过这个方法,按钮显示会有点慢,还是比较推荐方法A.
2. FireFox中 上传图标看不见
原因:没有安装Flash非IE内核的插件
解决方法:在FireFox中安装最新版本的非IE内核的插件
3. [b]onQueueFull [/b]函数提示两次
原因:在uploadify.js中 157行已经弹出提示,所以在页面中设置onQueueFull后会弹出两次提示
解决方法:将uploadify.js中 alert('The queue is full. The max size is ' + queueSizeLimit + '.');删除或将提示改为中文;
4. uploadify.js中的中文乱码(不修改uploadify.js不会出现这种情况)
原因:编码不统一,uploadify.js 采用UTF-8编码,ASP.NET环境默认为GB2312编码
解决方法:引用 uploadify.js 时添加 charset="gb2312"
5. 上传中文名称的文件时,Http Error
原因:在uploadify.swf中采用utf-8编码并上传图片,ASP.NET默认GB2312编码
解决方法:
A. 在HttpHander处理上传图片时,添加 context.Response.ContentEncoding = System.Text.Encoding.UTF8;
B. 在 Web.config 中添加如下代码
<globalization fileEncoding="UTF-8" requestEncoding="UTF-8" responseEncoding="UTF-8"/>
6. 关于上传成功后图片自动消失的问题
原因:在uploadify.js中第48行,有个属性:removeCompleted 该属性默认值为 true;表示自动移除上传成功的文件
解决方法:修改 removeCompleted 默认值为 false
原因:uploadify.js 中对使用escape()进行编码,在uploadify.swf中使用unescape()进行解码,js中的escape()方法是采用ISO Latin字符集对指定的字符串进行编码的,很明显咱们的中文,包括日文,韩文(CJK)都不包括在ISO Latin字符集里面的。
解决方法:
A. 修改插件
修改uploadify.js
将 if (settings.buttonText) data.buttonText = escape(settings.buttonText);
改为 if (settings.buttonText) data.buttonText = encodeURI(settings.buttonText);
修改uploadify.fla
将 browseBtn.empty.buttonText.text = unescape(param.buttonText);
改为 browseBtn.empty.buttonText.text = decodeURI(param.buttonText);
然后重新生成uploadify.swf并拷入项目中
B. 使用 buttonImg 参数
显然buttonImg是用来设置图片按钮的,自己做的图片,没编码当然不会乱码了,不过这个方法,按钮显示会有点慢,还是比较推荐方法A.
2. FireFox中 上传图标看不见
原因:没有安装Flash非IE内核的插件
解决方法:在FireFox中安装最新版本的非IE内核的插件
3. [b]onQueueFull [/b]函数提示两次
原因:在uploadify.js中 157行已经弹出提示,所以在页面中设置onQueueFull后会弹出两次提示
解决方法:将uploadify.js中 alert('The queue is full. The max size is ' + queueSizeLimit + '.');删除或将提示改为中文;
4. uploadify.js中的中文乱码(不修改uploadify.js不会出现这种情况)
原因:编码不统一,uploadify.js 采用UTF-8编码,ASP.NET环境默认为GB2312编码
解决方法:引用 uploadify.js 时添加 charset="gb2312"
5. 上传中文名称的文件时,Http Error
原因:在uploadify.swf中采用utf-8编码并上传图片,ASP.NET默认GB2312编码
解决方法:
A. 在HttpHander处理上传图片时,添加 context.Response.ContentEncoding = System.Text.Encoding.UTF8;
B. 在 Web.config 中添加如下代码
<globalization fileEncoding="UTF-8" requestEncoding="UTF-8" responseEncoding="UTF-8"/>
6. 关于上传成功后图片自动消失的问题
原因:在uploadify.js中第48行,有个属性:removeCompleted 该属性默认值为 true;表示自动移除上传成功的文件
解决方法:修改 removeCompleted 默认值为 false
相关文章推荐
- jquery uploadify在firefox上传附件存在的问题
- jquery uploadify上传插件兼容火狐问题
- jquery uploadify上传文件插件导致浏览器崩溃问题解决方法
- jquery uploadify上传文件插件导致浏览器崩溃问题解决方法
- jquery uploadify上传插件若干问题总结
- jQuery Uploadify上传插件使用中的问题 中文字符文件名转英文
- 使用jQuery Uploadify在ASP.NET 上传附件
- Jquery Uploadify上传带进度条的简单实例
- Uploadify & jQuery.imgAreaSelect 插件实现图片上传裁剪
- firefox浏览器用jquery.uploadify插件上传时报HTTP 302错误
- jquery+uploadify+springmvc文件上传
- JQuery.uploadify 上传文件插件的使用详解 for ASP.NET
- jquery.uploadify.v2.1.4实现图片切割上传
- 解决jQuery uploadify在非IE核心浏览器下无法上传
- jQuery uploadify在谷歌和火狐浏览器上传失败的解决方案
- Jquery Uploadify多文件上传带进度条 且传递自己的参数示例
- jquery.uploadify插件实现图片上传和预览效果
- jquery.uploadify 3.2.1+spring mvc上传文件
- jquery uploadify for asp 批量文件上传程序 整合风声asp无组件上传
- 记录-Jquery uploadify文件上传实例