/* ***************************
** Most of this code was kindly
** provided to me by
** Andrew Clover (and at doxdesk dot com)
** http://and.doxdesk.com/
** in response to my plea in my blog at
** http://worldtimzone.com/blog/date/2002/09/24
** It was unclear whether he created it.
*/
function utf8(wide) {
var c, s
var enc = ""
var i = 0
while(i c= wide.charCodeAt(i++)
// handle UTF-16 surrogates
if (c>=0xDC00 %26amp%26ampc<0xE000) continue
if (c>=0xD800 %26amp%26ampc<0xDC00) {
if (i>=wide.length) continue
s= wide.charCodeAt(i++)
if (s<0xDC00 || c>=0xDE00) continue
c= ((c-0xD800)<<10)+(s-0xDC00)+0x10000
}
// output value
if (c<0x80) enc += String.fromCharCode(c)
else if (c<0x800) enc += String.fromCharCode(0xC0+(c>>6),0x80+(c%26amp0x3F))
else if (c<0x10000) enc += String.fromCharCode(0xE0+(c>>12),0x80+(c>>6%26amp0x3F),0x80+(c%26amp0x3F))
else enc += String.fromCharCode(0xF0+(c>>18),0x80+(c>>12%26amp0x3F),0x80+(c>>6%26amp0x3F),0x80+(c%26amp0x3F))
}
return enc
}
var hexchars = "0123456789ABCDEF"
function toHex(n) {
return hexchars.charAt(n>>4)+hexchars.charAt(n %26amp0xF)
}
var okURIchars = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789_-"
function encodeURIComponentNew(s) {
var s = utf8(s)
var c
var enc = ""
for (var i= 0i if (okURIchars.indexOf(s.charAt(i))==-1)
enc += "%"+toHex(s.charCodeAt(i))
else
enc += s.charAt(i)
}
return enc
}
function URLEncode(fld)
{
if (fld == "") return false
var encodedField = ""
var s = fld
if (typeof encodeURIComponent == "function")
{
// Use javascript built-in function
// IE 5.5+ and Netscape 6+ and Mozilla
encodedField = encodeURIComponent(s)
}
else
{
// Need to mimic the javascript version
// Netscape 4 and IE 4 and IE 5.0
encodedField = encodeURIComponentNew(s)
}
//alert ("New encoding: " + encodeURIComponentNew(fld) +
// "\n escape(): " + escape(fld))
return encodedField
}
function _convert(str){
var arr = ["一","二","三","四","五","六","七","八","九","十"]
for (var i = 0 i < arr.length i++) {
str = str.replace(new RegExp(arr[i], "g"), (i+1))
}
return str
}
// 使用
var str = "一二三三九一"
var result = _convert(str)
result // 123391
var GB2312UnicodeConverter = {ToUnicode: function (str) {
return escape(str).toLocaleLowerCase().replace(/%u/gi, '\\u')
}
, ToGB2312: function (str) {
return unescape(str.replace(/\\u/gi, '%u'))
}
}
用此方法试试。
个人觉得这个转码的工作最好还是在接收端做