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

經常用vb寫的urlencoding很容易實現UrlEncode,以及利用
http://www.csdn.net/Develop/read_article.asp?id=13846
中的代碼很容易改寫成vbs從而實現部分漢字的拼音

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

Unicode和GB的轉換庫和UrlEncode和getSpell函數,請下載
http://www.blueidea.com/user/qswh/qswhU2GB.js

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

function UrlEncode(str){
 var i,c,ret="",strSpecial="!/"#$%&'()*+,/:;<=>?@[/]^`{|}~%";
 for(i=0;i<str.length;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<str.length;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是分隔符,範例如下
<script language=javascript src=qswhU2GB.js></script>

<script language=javascript>
document.write(UrlEncode("中文 <>/"#%{}|^~[]`&?+Abc"),"<br>")
document.write(getSpell("中國程序員大本營"),"<br>")
document.write(getSpell("秋水無恨","'"),"<br>")
</script>

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章