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

王朝vc·作者佚名  2006-01-08
窄屏简体版  字體: |||超大  

http://www.csdn.net/Develop/read_article.asp?id=15043

用的Unicode和GB的转换库如下地址

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<str.length;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<str.length;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是分隔符,范例如下

<script src=qswhGB2312.js></script>

<script language=javascript>

document.write(UrlEncode("中文 <>\"#%{}|^~[]`&?+Abc"),"<br>")

document.write(getSpell("中国程序员大本营"),"<br>")

document.write(getSpell("秋水无恨","'"),"<br>")

</script>

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

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有 導航