HTML、CSS、JS对unicode字符的不一样处理

unicode字符的不一样表示法

unicode字符在html、css和js中的表示方法均不相同,下面分别做介绍。javascript

原文发表于这里css

css表示法

首先来一段很常见的bootstrap的字体图标代码:html

.glyphicon-home:before { content: "\e021"; }

上面代码中的e021就是这个字符的unicode码,是16进制。java

语法:python

'\ + 16进制的unicode编码'

如:'\5b89'表示汉字“安”:bootstrap

<div class="test"></div> <style> .test: before {content: "\e021";} </style>

js表示方法

语法:测试

'\u + 16进制的unicode编码'

示例:字体

// 如:'\u5b89'表示汉字“安” console.log('\u5b89'); // 输出“安”

html表示方法

html特殊一点,使用的是10进制,一开始没注意这个搞的半天出不来郁闷好久。ui

语法:编码

'&# + 10进制的unicode编码 + 英文分号;'

& #23433;(注意,因为正常书写的话发表以后会被转换成汉字,因此我这里故意中间留了空格防止转换)表示汉字,结尾的分号经测试不加也没问题,可是最好仍是加一下。

<div> 这是unicode表示的字符“安”:& #23433;(这里故意留一空格防止转换) </div>

另外,一些特殊字符还有其它表示,也就是常说的html转义字符,如(因为自动转换问题,这里用图片表示):

完整的HTML转义字符表能够参见这里:

http://tool.oschina.net/commons?type=2

获取汉字的unicode编码

那么,如何知道一个汉字的unicode的编码呢?很简单:

'安'.charCodeAt(); // 输出的 23433 就是汉字 安 的unicode编码,不过注意是10进制的 String.fromCharCode(23433); // 输出 '安'

获得了10进制的unicode编码,再若是想在js和css里面用的话,就须要用toString(16)转16进制再作进一步处理了。

var unicode = '\\u'+'茗'.charCodeAt().toString(16); // 输出字符串:"\u8317" JSON.parse('"'+unicode+'"'); // 输出汉字:"茗" eval('"'+unicode+'"'); // 或者使用eval解析也能够
相关文章
相关标签/搜索