私はこれまでこれを行ったことがなく、なぜ悪名高い�
エンコーディング文字を出力するのかわかりません。文字を適切に出力する方法(ASCII + Unicode)に関するアイデアはありますか? \u0041
-\u005A
はUTF-8でA-Z
を出力する必要があると思います。Firefoxが報告しているのはページエンコーディングです。
var c = new Array("F","E","D","C","B","A",9,8,7,6,5,4,3,2,1,0);
var n = 0;
var d = "";
var o = "";
for (var i=16;i--;){
for (var j=16;j--;){
for (var k=16;k--;){
for (var l=16;l--;){
d = c[i].toString()
+ c[j].toString()
+ c[k].toString()
+ c[l].toString();
o += ( ++n + ": "
+ d + " = "
+ String.fromCharCode("\\u" + d)
+ "\n<br />" );
if(n>=500){i=j=k=l=0;} // stop early
}
}
}
}
document.write(o);
.fromCharCode()
関数は、文字列ではなく数値を取ります。そのような文字列をまとめて、パーサーがあなたが思うことをすることを期待することはできません。それは言語が機能する方法ではありません。
コードを修正して、16進数から文字列(「\ u」なし)を作成し、次のように呼び出すことができます。
_var n = parseInt(hexString, 16);
_
値を取得します。次に、.fromCharCode()
をthat valueで呼び出すことができます。
テキスト内のすべてのUnicodeエンコードされた特殊文字を置き換えるための便利なスニペットは次のとおりです。
var rawText = unicodeEncodedText.replace(
/\\u([0-9a-f]{4})/g,
function (whole, group1) {
return String.fromCharCode(parseInt(group1, 16));
}
);
replace
、 fromCharCode
および parseInt
を使用
_\unnnn
_構文を使用して文字を作成する場合は、コード内のリテラル文字列でそれを行う必要があります。動的に実行する場合は、実行時に評価されるリテラル文字列で実行する必要があります。
_var hex = "0123456789ABCDEF";
var s = "";
for (var i = 65; i <= 90; i++) {
var hi = i >> 4;
var lo = i % 16;
var code = "'\\u00" + hex[hi] + hex[lo] + "'";
var char = eval(code);
s += char;
}
document.write(s);
_
もちろん、String.fromCharCode(i)
を使用するだけの方がはるかに簡単です...