Js中實現拼音和UrlEncode的功能(利用GB和Unicode對照表) (轉)

worldblog發表於2007-12-12
Js中實現拼音和UrlEncode的功能(利用GB和Unicode對照表) (轉)[@more@]

經常用vb寫的urlencoding很容易實現UrlEncode,以及利用
/Develop/read_article.?id=13846中的程式碼">
中的程式碼很容易改寫成vbs從而實現部分漢字的拼音

但由於有些人需要完全用script寫,而預設是Unicode
所以就需要一個Unicode和GB的轉換庫

Unicode和GB的轉換庫和UrlEncode和getSpell,請
a.com/user/qswh/qswhU2GB.js">

var qswhU2GB=[];//Unicode和GB的對應表,略
var qswhSpell=[];//拼音的對照表,略

function UrlEncode(str){
 var i,c,ret="",strSpecial="!"#$%&'()*+,/:;<=>?@[]^`{|}~%";
 for(i=0;i if(str.charCodeAt(i)>=0x4e00){
 c=qswhU2GB[str.charCodeAt(i)-0x4e00];
 ret+="%"+c.slice(0,2)+"%"+c.slice(-2);
 }
 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,ret="";
 if(sp==null)sp="";
 for(i=0;i if(str.charCodeAt(i)>=0x4e00){
 c=parseInt(qswhU2GB[str.charCodeAt(i)-0x4e00],16);
 if(c<55290){
 for(t=qswhSpell.length-1;t>0;t=t-2)if(qswhSpell[t]<=c)break;
 if(t>0)ret+=qswhSpell[t-1]+sp;
 }
 }
 }
 return ret.substr(0,ret.length-sp.length);
}

sp是分隔符,範例如下


來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/10752043/viewspace-991714/,如需轉載,請註明出處,否則將追究法律責任。

相關文章