emoji好像是UTF-16的,直接存DB里mysql的格式设置好像比较麻烦。
我转了一下从utf16转成"😂" 这种类型了。
但是页面上显示的时候,还是显示这个string型,并不显示emoji的图片。
而如果我把它重新转回utf-16型,就显示成空了。
代码如下:
function utf16toEntities(str) {
var patt = /[\ud800-\udbff][\udc00-\udfff]/g;
str = str.replace(patt, function (char) {
var H, L, code;
if (char.length === 2) {
H = char.charCodeAt(0); // 取出高位
L = char.charCodeAt(1); // 取出低位
code = (H - 0xD800) * 0x400 + 0x10000 + L - 0xDC00;
return “&#” + code + “;”;
} else {
return char;
}
});
return str;
}
function entitiestoUtf16(str) {
// 检测出形如〹形式的字符串
var strObj = utf16toEntities(str);
var patt = /&#\d+;/g;
var H, L, code;
var arr = strObj.match(patt) || [];
for (var i = 0; i < arr.length; i++) {
code = arr[i];
code = code.replace(’&#’, ‘’).replace(’;’,’’);
// 高位
H = Math.floor((code - 0x10000) / 0x400) + 0xD800;
// 低位
L = (code - 0x10000) % 0x400 + 0xDC00;
code = “&#” + code + “;”;
var s = String.fromCharCode(H, L);
strObj = strObj.replace(code, s);
}
return strObj;
}