[有人可以指导我如何在javascript中将char转换为十六进制吗?例如:
“入力されたデータは范囲外です。”“ \ u5165 \ u529B \ u3055 \ u308C \ u305F \ u30C7 \ u30FC \ u30BF \ u306F \ u7BC4 \ u56F2 \ u5916 \ u3067 \ u3059 \ u3002”
但是我无法弄清楚。
任何建议。
谢谢,萨伯塔姆
您可以遍历字符并使用charCodeAt
函数获取其UTF-16值,然后使用它们构造一个字符串。
我构建的一些代码比您链接的站点上的代码要好得多,并且应该更容易理解:
function string_as_unicode_escape(input) {
function pad_four(input) {
var l = input.length;
if (l == 0) return '0000';
if (l == 1) return '000' + input;
if (l == 2) return '00' + input;
if (l == 3) return '0' + input;
return input;
}
var output = '';
for (var i = 0, l = input.length; i < l; i++)
output += '\\u' + pad_four(input.charCodeAt(i).toString(16));
return output;
}
让我们分解一下。
string_as_unicode_escape
接受一个参数,input
,它是一个字符串。pad_four
是一个内部函数,可以执行一件事;它使用前导'0'
字符填充字符串,直到长度至少为四个字符为止。output
定义为空字符串。\u
附加到output
字符串中。用input.charCodeAt(i)
取字符的UTF-16值,然后用.toString(16)
转换为十六进制字符串,然后用前导零填充,然后将结果附加到output
字符串。output
字符串。正如Tim Down所评论的,我们还可以将0x10000
添加到charCodeAt
值,然后将.slice(1)
添加到调用.toString(16)
的字符串上,以实现填充效果。
function string_as_unicode_escape(str){
return str.split("").map(function(s){
return "\\u"+("0000" + s.charCodeAt(0).toString(16)).slice(-4);
}).join("");
}
var hex = new Array('0','1','2','3','4','5','6','7','8','9','a ','b','c','d','e','f');
function stringEncode()
{
var x=document.getElementById("from_text");
var preescape="" + x.value;
var escaped="";
var i=0;
for(i=0;i<preescape.length;i++)
{
escaped=escaped+encodeChar(preescape.charAt(i));
}
//x=document.getElementById("to_text");
x.value=escaped;
//alert("Codigo: "+escapeHtml(escaped));
//document.getElementById('string_example').innerHTML="<b>String example with text</b><br/><br/>String s=\""+escapeHtml(escaped)+"\";<br/><br/>";
}
function escapeHtml(unsafe) {
return unsafe
.replace(/&/g, "&")
.replace(/</g, "<")
.replace(/>/g, ">")
.replace(/"/g, """)
.replace(/'/g, "'");
}
function encodeChar(original)
{
var found=true;
var thecharchar=original.charAt(0);
var thechar=original.charCodeAt(0);
switch(thecharchar) {
case '\n': return "\\n"; break; //newline
case '\r': return "\\r"; break; //Carriage return
case '\'': return "\\'"; break;
case '"': return "\\\""; break;
case '\\': return "\\\\"; break;
case '\t': return "\\t"; break;
case '\b': return "\\b"; break;
case '\f': return "\\f"; break;
default:
found=false;
break;
}
if(!found)
{
if(thechar>127) {
var c=thechar;
var a4=c%16;
c=Math.floor(c/16);
var a3=c%16;
c=Math.floor(c/16);
var a2=c%16;
c=Math.floor(c/16);
var a1=c%16;
// alert(a1);
return "\\u"+hex[a1]+hex[a2]+hex[a3]+hex[a4]+"";
}
else
{
return original;
}
}
}
// ------------------------ lolamarias con
您可以为此使用普通的replace()
。
'! \u0100 力 😃'.replace(
/[^\x00-\xFF]/g,
function(ch) {
return ('\\u0' + ch.charCodeAt(0).toString(16))
.replace(/0(?=....$)/, '');
}
)
产生! \u0100 \u529b \ud83d\ude03
非常简洁,可以处理填充问题,而不会造成麻烦的if
或慢的slice()
s。与in all browsers不同,可以工作map()
。请注意,它如何仅替换需要的字符(!
和未触及),而不会造成麻烦的迭代或缓慢的
split()
处理。与其他答案一样,它也可以正确处理代理对(😃
变成两个字节\ud83d\ude03
)。
如果打算多次重用该函数,则将其放在自己的函数中并使两个正则表达式保持静态也会使其更快。
如果确实需要,可以通过将[^\x00-\xFF]
更改为.
,将\\u0
更改为\\u000
,将/0(
更改为/0+(
来处理所有字符。