Unicode与字符汉字相互转换
浏览:4987次 出处信息
/*
常用中文的unicode码的范围是4E00 ~ 9FA5,不包含全角在内,具体编码参见http://www.unicode.org/Public/5.0.0/ucd/Unihan.html
*/
1、将汉字转换为unicode
主要利用javascript正则表达式中的\uxxxx进行匹配,对匹配结果使用escape和replace,该方法仅对汉字有效:
|
1
2
3
4
5
6 |
function unicode_only_chs(str){ // str = "测试test" return str.replace(/([^\u0000-\u00FF])/g, function($0){ // $0 = "测","试" var tmp = escape($0); // tmp = "%u6D4B","%u8BD5" return tmp.replace(/(%u)(\w{4})/gi,"\\u$2") // 将"%u"替换为"\u",即"\u6D4B" }); } |
2、将全部字符转换为unicode
利用charCodeAt()和toString(16)即可实现:
|
1
2
3
4
5
6
7
8
9
10 |
function unicode_all(str){ // str = "测试test" return str.replace(/([\u0000-\uFFFF])/g, function($0){ // $0 = "测","试","t","e","s","t" if($0.charCodeAt() < 256) { return '\\u00' + $0.charCodeAt().toString(16); // 0 ~ 255的英文字符 } else { return '\\u' + $0.charCodeAt().toString(16); } }); } |
3、unicode转换为字符和汉字
主要利用String.fromCharCode()和parseInt(,16):
|
1
2
3
4
5
6 |
function reconvert(str){ str = str.replace(/(\\u)(\w{4}|\w{2})/gi, function($0,$1,$2){ return String.fromCharCode(parseInt($2,16)); }); return str; } |
Demo
建议继续学习:
- 字符编码和中文乱码小叙 (阅读:6822)
- 中文编码杂谈 (阅读:6054)
- Hadoop的map/reduce作业输入非UTF-8编码数据的处理原理 (阅读:5448)
- PHP编码规范 (阅读:5387)
- Linux screen窗口中文乱码问题 (阅读:5112)
- UTF-8编码中BOM的检测与删除 (阅读:4987)
- base64_encode 和 urlencode (阅读:4958)
- python-django的中文编码总结 (阅读:4811)
- JAVASCRIPT完美实现UTF8页面提交数据到GB2312 (阅读:4648)
- 自动检测字符编码函数mb_detect_encoding (阅读:4447)
QQ技术交流群:445447336,欢迎加入!
扫一扫订阅我的微信号:IT技术博客大学习
扫一扫订阅我的微信号:IT技术博客大学习
<< 前一篇:PHP正则匹配字符串中的标签
后一篇:让PHP更快的提供文件下载 >>
文章信息
- 作者:tinyliu 来源: Accumulating
- 标签: Unicode 编码
- 发布时间:2012-04-19 23:45:04
建议继续学习
近3天十大热文
-
[784] WordPress插件开发 -- 在插件使用 -
[61] Java将Object对象转换为String -
[60] cookie窃取和session劫持 -
[58] 学习:一个并发的Cache -
[55] 你必须了解的Session的本质 -
[52] 最萌域名.cat背后的故事:加泰与西班牙政府 -
[50] Linux如何统计进程的CPU利用率 -
[50] 解读iPhone平台的一些优秀设计思路 -
[49] 再谈“我是怎么招聘程序员的” -
[48] 豆瓣是啥?
