JS实现汉字与Unicode码相互转换的方法详解
本文实例讲述了JS实现汉字与Unicode码相互转换的方法。分享给大家供大家参考,具体如下:
js文件中,有些变量的值可能会含有汉字,画面引入js以后,有可能会因为字符集的原因,把里面的汉字都变成乱码。后来发现网上的一些js里会把变量中的汉字都表示成”\u“开头的16进制编码,这样应该可以解决上面的问题。
最近有时间在网上查找了一下实现方式,一种比较大众化的:
function tounicode(data) { if(data == '') return '请输入汉字'; var str =''; for(var i=0;i<data.length;i++) { str+="\\u"+parseInt(data[i].charCodeAt(0),10).toString(16); } return str; } function tohanzi(data) { if(data == '') return '请输入十六进制unicode'; data = data.split("\u"); var str =''; for(var i=0;i<data.length;i++) { str+=String.fromCharCode(parseInt(data[i],16).toString(10)); } return str; }
还找到一个相对简单一些,但比较另类的:
var GB2312UnicodeConverter={ ToUnicode:function(str){ return escape(str).toLocaleLowerCase().replace(/%u/gi,'\\u'); } ,ToGB2312:function(str){ return unescape(str.replace(/\\u/gi,'%u')); } };
不过都有些问题,这两种方式,都会把出汉字以外的其他字符都给转换掉,做个简单的加密解密算法还是可以的,但要是用来处理js文件,把回车、换行、空格、tab字符全换了,转完以后,js文件也没法运行了。
偷懒不成,只能自己按照上面代码处理逻辑写一个了,只要保证只转换汉字字符就可以了:
// 汉字转为Unicode字符码表示 function toUnicode(s){ return s.replace(/([\u4E00-\u9FA5]|[\uFE30-\uFFA0])/g,function(){ return "\\u" + RegExp["$1"].charCodeAt(0).toString(16); }); }
方法写完了,为了方便转换js文件的内容,再做个简单的页面,加一个button在画面上。先要做的是在js文件Ctr+A,Ctr+C,把内容拷贝 到剪贴板里,然后再新建的这个画面上,点button的时候,从剪贴板里把内容读出来,调用方法转一下,在把内容放回剪贴板。然后再到 js文件里Ctr+A,Ctr+V一下就可以了。代码如下:
<html> <head> <script language="javascript"> function Window_Load(){ var G = document.getElementById; G("cmdToU").onclick = function(){ clipboardData.setData("text",toUnicode(clipboardData.getData("text"))); } } // 汉字转为Unicode字符码表示 // 原函数是,红色是是错误的,导致多个中文时,结果都是最后一个汉字的unicode码; function toUnicode(s){ return s.replace(/([\u4E00-\u9FA5]|[\uFE30-\uFFA0])/g,function(){ return "\\u" + RegExp["$1"].charCodeAt(0).toString(16); }); } // 经@b4b4指正,现更改 function toUnicode(s){ return s.replace(/([\u4E00-\u9FA5]|[\uFE30-\uFFA0])/g,function(newStr){ return "\\u" + newStr.charCodeAt(0).toString(16); }); } </script> </head> <body onload="Window_Load();"> <button id="cmdToU">汉字转为Unicode</button> </body> </html>
这个页面只能在IE内核的浏览器下才能正常运行,因为clipboardData对象好像只在IE下面有。
PS:这里再为大家提供几款Unicode编码转换操作相关工具供大家参考使用:
在线Unicode/中文转换工具:
http://tools.jb51.net/transcoding/unicode_chinese
Native/Unicode在线编码转换工具:
http://tools.jb51.net/transcoding/native2unicode
在线中文汉字/ASCII码/Unicode编码互相转换工具:
http://tools.jb51.net/transcoding/chinese2unicode
更多关于JavaScript相关内容可查看本站专题:《javascript编码操作技巧总结》、《JavaScript加密解密技巧汇总》、《JavaScript错误与调试技巧总结》、《JavaScript数据结构与算法技巧总结》、《JavaScript遍历算法与技巧总结》及《JavaScript数学运算用法总结》
希望本文所述对大家JavaScript程序设计有所帮助。
您可能感兴趣的文章:
- JS将unicode码转中文方法
- js 中文汉字转Unicode、Unicode转中文汉字、ASCII转换Unicode、Unicode转换ASCII、中文转换XX函数代码
- Json_encode防止汉字转义成unicode的方法
- js unicode 编码解析关于数据转换为中文的两种方法
- 如何让Jackson JSON生成的数据包含的中文以unicode方式编码
- javascript unicode与GBK2312(中文)编码转换方法
- 无语,javascript居然支持中文(unicode)编程!
- 解决JSON.stringify()自动将中文转译成unicode的问题
- JS实现的汉字与Unicode码相互转化功能分析
- JS实现的汉字与Unicode码相互转化功能分析
- JS实现数字转换为货币汉字大写数字的方法详解
- JS实现数字转换为货币汉字大写数字的方法详解
- JS实现将数字金额转换为大写人民币汉字的方法
- JS对象与json字符串相互转换实现方法示例
- JS实现数字格式千分位相互转换方法
- json对象与数组以及转换成js对象的简单实现方法
- js实现跨域的方法实例详解
- unity 得到js的Json,类似\u624b\u8868这种转换为汉字的方法
- JSPatch实现原理详解:让JS调用/替换任意OC方法
- 如何在JS中实现相互转换XML和JSON
- JS中实现JSON对象和JSON字符串之间的相互转换
- Android的Gson的使用方法,实现Json结构间相互转换
- 使用纯JS代码判断字符串中有多少汉字的实现方法(超简单实用)
- JS实现焦点图轮播效果的方法详解
- js实现完美兼容各大浏览器的人民币大小写相互转换
- Datawindow通过Json接口实现数据操作时(三层)PHP5.2 json_encode时发现汉字转换成了\u表示的处理方法
- js字符串转换成数字与数字转换成字符串的实现方法
- js实现完美兼容各大浏览器的人民币大小写相互转换
- js图片放大镜效果实现方法详解