JS 文字符串轉換unicode編碼函數(shù)
更新時間:2009年05月30日 22:37:45 作者:
AJAX傳遞中文字符串時必須把中文字符串編碼成unicode,一般會用到JS的自帶函數(shù)escape().不過找到了更好的函數(shù)來確決中文字符轉換成unicode編碼的函數(shù)
復制代碼 代碼如下:
function uniencode(text)
{
text = escape(text.toString()).replace(/\+/g, "%2B");
var matches = text.match(/(%([0-9A-F]{2}))/gi);
if (matches)
{
for (var matchid = 0; matchid < matches.length; matchid++)
{
var code = matches[matchid].substring(1,3);
if (parseInt(code, 16) >= 128)
{
text = text.replace(matches[matchid], '%u00' + code);
}
}
}
text = text.replace('%25', '%u0025');
return text;
}
當然服務器端要對編碼過的字符串進行第二次轉碼.把字符串轉換成UTF-8編碼.
復制代碼 代碼如下:
function convert_int_to_utf8($intval)
{
$intval = intval($intval);
switch ($intval)
{
// 1 byte, 7 bits
case 0:
return chr(0);
case ($intval & 0x7F):
return chr($intval);
// 2 bytes, 11 bits
case ($intval & 0x7FF):
return chr(0xC0 | (($intval >> 6) & 0x1F)) .
chr(0x80 | ($intval & 0x3F));
// 3 bytes, 16 bits
case ($intval & 0xFFFF):
return chr(0xE0 | (($intval >> 12) & 0x0F)) .
chr(0x80 | (($intval >> 6) & 0x3F)) .
chr (0x80 | ($intval & 0x3F));
// 4 bytes, 21 bits
case ($intval & 0x1FFFFF):
return chr(0xF0 | ($intval >> 18)) .
chr(0x80 | (($intval >> 12) & 0x3F)) .
chr(0x80 | (($intval >> 6) & 0x3F)) .
chr(0x80 | ($intval & 0x3F));
}
}
這樣中文字符串就可以轉換成UTF-8編碼.這種方法適合各種服務器環(huán)境..
您可能感興趣的文章:
- js 編碼轉換 gb2312 和 utf8 互轉的2種方法
- Javascript下的urlencode編碼解碼方法附decodeURIComponent
- js對圖片base64編碼字符串進行解碼并輸出圖像示例
- js 顯示base64編碼的二進制流網(wǎng)頁圖片
- utf-8編碼引起js輸出中文亂碼的解決辦法
- 通過javascript進行UTF-8編碼的實現(xiàn)方法
- 將字符串轉換成gb2312或者utf-8編碼的參數(shù)(js版)
- JavaScript Base64編碼和解碼,實現(xiàn)URL參數(shù)傳遞。
- JavaScript實現(xiàn)Base64編碼轉換
- js下用gb2312編碼解碼實現(xiàn)方法
- JS實現(xiàn)的哈夫曼編碼示例【原始版與修改版】
相關文章
Bootstrap popover 實現(xiàn)鼠標移入移除顯示隱藏功能方法
下面小編就為大家分享一篇Bootstrap popover 實現(xiàn)鼠標移入移除顯示隱藏功能方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-01-01javascript js 操作數(shù)組 增刪改查的簡單實現(xiàn)
下面小編就為大家?guī)硪黄猨avascript js 操作數(shù)組 增刪改查的簡單實現(xiàn)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-06-06利用JavaScript實現(xiàn)靜態(tài)圖片局部流動效果
如果你有玩過《王者榮耀》、《陰陽師》?等手游,一定注意到過它的啟動動畫、皮膚立繪卡片等場景,經常采用靜態(tài)底圖加局部液態(tài)流動效果的簡單動畫,本文將利用JavaScript實現(xiàn)這一效果,需要的可以參考一下2022-08-08Bootstrap與KnockoutJs相結合實現(xiàn)分頁效果實例詳解
KnockoutJS是一個JavaScript實現(xiàn)的MVVM框架。接下來通過本文給大家介紹Bootstrap與KnockoutJs相結合實現(xiàn)分頁效果,對bootstrap knockoutjs相關知識感興趣的朋友一起學習吧2016-05-05