Uploadify_加载速度慢等问题_解决方案

 1. buttonText 属性设置中文无效的问题或加载速度慢(2秒左右)


    原因: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. onQueueFull 函数提示两次


    原因:在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有一个参数是buttonText这个无论你怎么改都不支持中文,因为插件在js里用了一个转码方法把这个参数的值转过码了,解码的地方在那个swf文件里,看不到代码,所以这条路不行。另一个参数,网上很少提到,是buttonImg(按钮图片),这时你完全可以用一个图片来替换掉插件自带的那个黑色的flash浏览按钮,只要你自己的图片上是中文,这不就解决了中文按钮问题么?如果只加这一个,你会发现你的按钮图片下面有一片白色区域,其实就是那个flash留下的,白色区域表示鼠标可用范围,这个范围可以用width,height来调整。还有一个参数wmode它的默认值是opaque,把它改成transparent就行了,也就是把那片白色区域透明化。再用刚才说的方法,把按键点击范围设置成跟你图片一样大就完全OK了。 

 

方法二:

 

uploadify 控件的按钮不支持多国语言,这里介绍如何修改后使其支持多国语言。

1.jquery.uploadify.v2.1.4.js文件 70行

原代码:if (settings.buttonText) data.buttonText = escape(settings.buttonText);

新代码:if (settings.buttonText) data.buttonText = encodeURI(settings.buttonText);

 

2.jquery.uploadify.v2.1.4.min.js文件 863列

原代码:if(f.buttonText){g.buttonText=escape(f.buttonText)}

新代码:if(f.buttonText){g.buttonText=encodeURI(f.buttonText)}

 

3.uploadify.fla文件 Scene 1 脚本文件 117行

原代码:browseBtn.empty.buttonText.text = unescape(param.buttonText);

新代码:browseBtn.empty.buttonText.text = decodeURI(param.buttonText);

 

4.uploadify.fla文件 Scene 1>empty>buttonText 属性>字符>系列

原值:Helvetica

新值:_sans

 

5.uploadify.fla文件 删除(Delete) Scene 1>Helvetica


转载于:https://my.oschina.net/miaowang/blog/469196

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值