JavaScriptで文字をASCIIコードに変換する


952

JavaScriptを使用して文字をASCIIコードに変換するにはどうすればよいですか?

例えば:

「\ n」から10を取得します。


10
ほとんどの回答で提案されているString.prototype.charCodeAt()メソッドは、UTF-16コードユニットを返します(歴史的な理由により、完全な適切なUTF-16エンコーディングでさえも)。最初の128個のUnicodeコードポイントのみが、ASCII文字エンコーディングと直接一致します。
アルバロゴンサレス

回答:


1448
"\n".charCodeAt(0);

658
これの反対はですString.fromCharCode(10)
viam0Zah 2011年

184
面白い事実:(0最初の引数の値)は本当に必要ありません—必要なだけ"\n".charCodeAt()です。
Mathias Bynens、2011年

47
@MathiasBynens:そして幸いにもこれは文書化されています:developer.mozilla.org/en/JavaScript/Reference/Global_Objects/…。「それは、数、0がデフォルトでない場合は」
tokland

12
とは異なりString.fromCharCode( asciiNumVal )stringInstance.charCodeAt( index )はStringクラスの静的メソッドではないことを指摘する必要があります
bobobobo

26
@Mathias Bynens、それは確かにデフォルトでゼロになりますが、私はパフォーマンスについて興味のないテストを実行しました、そしてそれは** 0を使用して比較すると比較的ひどく実行されます。jsperf.com/default-to- 0 -vs- 0 /4 **その相対的な違いのみ、いずれにしても非常に迅速です。
ウェイドモンタギュー2013年

386

String.prototype.charCodeAt()文字列文字をASCII番号に変換できます。例えば:

"ABC".charCodeAt(0) // returns 65

String.fromCharCode(10)数値を同じASCII文字に変換する反対の使用法。この関数は複数の数値を受け入れ、すべての文字を結合してから文字列を返すことができます。例:

String.fromCharCode(65,66,67); // returns 'ABC'

以下は、簡単なASCII文字のリファレンスです。

{
"31": "",      "32": " ",     "33": "!",     "34": "\"",    "35": "#",    
"36": "$",     "37": "%",     "38": "&",     "39": "'",     "40": "(",    
"41": ")",     "42": "*",     "43": "+",     "44": ",",     "45": "-",    
"46": ".",     "47": "/",     "48": "0",     "49": "1",     "50": "2",    
"51": "3",     "52": "4",     "53": "5",     "54": "6",     "55": "7",    
"56": "8",     "57": "9",     "58": ":",     "59": ";",     "60": "<",    
"61": "=",     "62": ">",     "63": "?",     "64": "@",     "65": "A",    
"66": "B",     "67": "C",     "68": "D",     "69": "E",     "70": "F",    
"71": "G",     "72": "H",     "73": "I",     "74": "J",     "75": "K",    
"76": "L",     "77": "M",     "78": "N",     "79": "O",     "80": "P",    
"81": "Q",     "82": "R",     "83": "S",     "84": "T",     "85": "U",    
"86": "V",     "87": "W",     "88": "X",     "89": "Y",     "90": "Z",    
"91": "[",     "92": "\\",    "93": "]",     "94": "^",     "95": "_",    
"96": "`",     "97": "a",     "98": "b",     "99": "c",     "100": "d",    
"101": "e",    "102": "f",    "103": "g",    "104": "h",    "105": "i",    
"106": "j",    "107": "k",    "108": "l",    "109": "m",    "110": "n",    
"111": "o",    "112": "p",    "113": "q",    "114": "r",    "115": "s",    
"116": "t",    "117": "u",    "118": "v",    "119": "w",    "120": "x",    
"121": "y",    "122": "z",    "123": "{",    "124": "|",    "125": "}",    
"126": "~",    "127": ""
}

30
より良いasciiリファレンス:en.wikipedia.org/wiki/ASCII-そのページのテーブルに私が行ったカラーリングは、ほぼ10年後もそこに残っていることを誇りに思います:)
BT

9
@theGrayFox C:\> man asciiが提供するものBad command or file name
e2-e4

これらのメソッドはUTF-16互換であることに注意してください。つまり、入力文字列に応じて、charCodeAtは1バイトのASCII値0〜127をはるかに超えて拡張できます。javascriptが任意の文字列入力を受け入れて処理している場合は、その範囲にあると想定しないでください。
theferrit32

31

文字がなく文字が1つしかない場合は、以下を使用できます。

'\n'.charCodeAt();

0を省略...

それは遅いです。現在のバージョンのChromeでは、5倍遅くなります。


10
これには実際には時間がかかります。ゼロを使​​用する方が高速です。(私のコンピューターでは、2倍の時間がかかりました
royhowie 2014年

23

他の答えは正しいですが、私はこの方法を好みます:

function ascii (a) { return a.charCodeAt(0); }

次に、それを使用するには、単に:

var lineBreak = ascii("\n");

これを小さなショートカットシステムに使用しています。

$(window).keypress(function(event) {
  if (event.ctrlKey && event.which == ascii("s")) {
    savecontent();
    }
  // ...
  });

そして、あなたはmap()または他のメソッドの中でそれを使うことさえできます:

var ints = 'ergtrer'.split('').map(ascii);

ちょうど美しさのためにそれを書く新しいES6方法: const ascii = a => a.charCodeAt(0);
axkibe

20

文字列のすべてのASCIIコードの合計を取得したい場合:

'Foobar'
  .split('')
  .map(x=>x.charCodeAt(0))
  .reduce((a,b)=>a+b);

または、ES6:

[...'Foobar']
  .map(char => char.charCodeAt(0))
  .reduce((current, previous) => previous + current)

1
最後の行を再確認してください。
Ypnypn 2015年

エレガント!関数として:function ascii(str){return str .split( '').map(function(char){return char + ":" + String(char.charCodeAt(0))+ "\ n";}) .reduce(function(current、previous){return current + previous;}); }
ダレングリフィス

1
[...'Foobar'].reduce((i,s)=>s.charCodeAt(0)+i,0)
ニック・

1
文字列内のすべてのASCIIコードの合計を求める人はいませんでした。
カールスミス

8

JavaScriptは文字列をUTF-16(2バイト)として格納するため、2番目のバイトを無視する場合は、ビット単位の&演算子0000000011111111(つまり255)を使用してそれを取り除きます。

'a'.charCodeAt(0) & 255 === 97; // because 'a' = 97 0 
'b'.charCodeAt(0) & 255 === 98; // because 'b' = 98 0 
'✓'.charCodeAt(0) & 255 === 19; // because '✓' = 19 39

なぜ2番目のバイトを無視したいのですか?
Roberg

3
質問は、UTF-16文字列(2バイト)からASCIIを生成することについて尋ねています。遅かれ早かれ、2番目のバイトを無視できなかった場合、非ASCIIコードを取得します。
Steven de Salas 2017年

1
@Steven de Salas-非ASCII文字の非ASCIIコードを取得するための「解決策」は、間違った ASCIIコードを返すことですか?
カールスミス

@CarlSmith、間違ったものではありません。キャラクターの非ASCIIコンポーネントを取り除くだけです。シングルバイトで作業している場合、これは便利です。ただし、プロジェクトには別のソリューションが必要な場合があります。
Steven de Salas

4

完全なUnicodeサポートと可逆性を確保するには、次の使用を検討してください。

'\n'.codePointAt(0);

これにより、UTF-16の制限を超えて文字をテストするときに、実際のコードポイント値を取得できます。

例えば

'𐩕'.codePointAt(0); // 68181
String.fromCodePoint(68181); // '𐩕'

'𐩕'.charCodeAt(0);  // 55298
String.fromCharCode(55298);  // '�'

特殊文字を16進表記に変換すると、一部のテキストエディターがそのような文字を直接処理する必要があるため、適切に機能しない場合があるので、便利な場合もあります。EG:alert(str.hexEncode()。hexDecode());
ホセTepedino

2

あなたは文字を入力し、このコードを使用してアスキーコードを取得できます

たとえば、ASCIIコード65を取得するような文字を入力します

function myFunction(){
    var str=document.getElementById("id1");
    if (str.value=="") {
       str.focus();
       return;
    }
    var a="ASCII Code is == >  ";
document.getElementById("demo").innerHTML =a+str.value.charCodeAt(0);
}
<p>Check ASCII code</p>

<p>
  Enter any character:  
  <input type="text" id="id1" name="text1" maxLength="1">	</br>
</p>

<button onclick="myFunction()">Get ASCII code</button>

<p id="demo" style="color:red;"></p>


1

ES6からすべてのUTF-16(非BMP /補足文字)をサポートするために、string.codePointAt()メソッドを使用できます。

このメソッドはcharCodeAtの改良版であり、65536(2 16-単一の16ビット)未満のUnicodeコードポイントのみをサポートできます。


4
これは、Internet Explorer のどのバージョンでサポートされていないことに言及する価値String.prototype.codePointAt()あります。(ただし、Edgeでサポートされています。)ここでポリフィルを取得できます
mgthomas99 2017
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.