ITPub博客

首页 > 应用开发 > Java > JS(Unicode->GB)的精简版(仍含拼音和UrlEncode) (转)

JS(Unicode->GB)的精简版(仍含拼音和UrlEncode) (转)

原创 Java 作者:worldblog 时间:2007-12-12 10:45:01 0 删除 编辑
JS(Unicode->GB)的精简版(仍含拼音和UrlEncode) (转)[@more@]

.NET/Develop/read_article.ASP?id=15043">http://www.csdn.net/Develop/read_article.asp?id=15043
用的Unicode和GB的转换库如下地址
idea.com/user/qswh/qswhU2GB.js">http://www.blueidea.com/user/qswh/qswhU2GB.js
148k的js,本地测试没有问题,但搁到网上就会觉得有点慢了

所以需要一个精简版,采录的只是GB2312编码,即部分GBK,但够用即可
这次特别精简了代码,但功能不变,区别只是该版只能作用于常见汉字。
什么马配什么鞍,也修改了UrlEncode和getSpell的算法,请大家不要混淆。
这次qswhGB2312.js只有18k,可在网上随意使用

Unicode和GB的转换库和UrlEncode和getSpell函数,请下载
http://www.blueidea.com/user/qswh/qswhGB2312.js

主要代码如下
var strGB="啊阿...鼾齄";//GB2312的字符串,略
var qswhSpell=["a",0,..,"zuo",3747];//拼音的对照表,略
function UrlEncode(str){
 var i,c,p,q,ret="",strSpecial="!"#$%&'()*+,/:;<=>?@[]^`{|}~%";
 for(i=0;i if(str.charCodeAt(i)>=0x4e00){
 var p=strGB.indexOf(str.charAt(i));
 if(p>=0){
 q=p%94;
 p=(p-q)/94;
 ret+=("%"+(0xB0+p).toString(16)+"%"+(0xA1+q).toString(16)).toUpperCase();
 }
 }
 else{
 c=str.charAt(i);
 if(c==" ")
 ret+="+";
 else if(strSpecial.indexOf(c)!=-1)
 ret+="%"+str.charCodeAt(i).toString(16);
 else
 ret+=c;
 }
 }
 return ret;
}

function getSpell(str,sp){
 var i,c,t,p,ret="";
 if(sp==null)sp="";
 for(i=0;i if(str.charCodeAt(i)>=0x4e00){
 p=strGB.indexOf(str.charAt(i));
 if(p>-1&&p<3755){
 for(t=qswhSpell.length-1;t>0;t=t-2)if(qswhSpell[t]<=p)break;
 if(t>0)ret+=qswhSpell[t-1]+sp;
 }
 }
 }
 return ret.substr(0,ret.length-sp.length);
}

sp是分隔符,范例如下



ps.该文章现仅限在csdn文档中心,如要转载,请和作者联系,否则后果自负。


来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/10752043/viewspace-991774/,如需转载,请注明出处,否则将追究法律责任。

请登录后发表评论 登录
全部评论
  • 博文量
    6241
  • 访问量
    2406146