Ubah karakter menjadi kode ASCII dalam JavaScript

952

Bagaimana saya bisa mengkonversi karakter ke kode ASCII menggunakan JavaScript?

Sebagai contoh:

dapatkan 10 dari "\ n".

levik
sumber
10
Harap dicatat bahwa metode String.prototype.charCodeAt () yang disarankan dalam sebagian besar jawaban akan mengembalikan unit kode UTF-16 (bahkan pengkodean UTF-16 penuh yang tidak tepat karena alasan historis). Hanya 128 poin kode Unicode pertama yang cocok langsung dengan pengkodean karakter ASCII.
Álvaro González

Jawaban:

1448
"\n".charCodeAt(0);
Jim
sumber
658
Kebalikan dari ini adalah String.fromCharCode(10).
viam0Zah
184
Fakta menyenangkan: Anda tidak benar-benar membutuhkan 0(nilai argumen pertama) - cukup "\n".charCodeAt()lakukan.
Mathias Bynens
47
@MathiasBynens: dan untungnya ini didokumentasikan: developer.mozilla.org/en/JavaScript/Reference/Global_Objects/… . "jika bukan angka, defaultnya adalah 0"
tokland
12
Anda harus menunjukkan bahwa tidak seperti String.fromCharCode( asciiNumVal ), stringInstance.charCodeAt( index )adalah tidak metode statis kelas String
bobobobo
26
@Mathias Bynens, Ini tentu saja default ke nol tapi saya hanya menjalankan tes hanya menarik pada kinerja dan itu melakukan ** relatif buruk dibandingkan menggunakan 0. jsperf.com/default-to-0-vs-0/4 ** Perbedaannya relatif saja, bagaimanapun caranya sangat sangat cepat.
mengarungi montague
386

String.prototype.charCodeAt()dapat mengonversi karakter string ke angka ASCII. Sebagai contoh:

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

Untuk penggunaan sebaliknya String.fromCharCode(10), ubah angka menjadi karakter ASCII yang sama. Fungsi ini dapat menerima beberapa angka dan bergabung dengan semua karakter kemudian mengembalikan string. Contoh:

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

Berikut adalah referensi karakter ASCII cepat:

{
"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": ""
}
Mohsen
sumber
30
Referensi ascii yang lebih baik: en.wikipedia.org/wiki/ASCII - Saya cukup bangga pewarnaan yang saya lakukan untuk tabel di halaman itu tetap ada setelah hampir 10 tahun
:)
9
@theGrayFox C:\> man asciimemberikanBad command or file name
e2-e4
Perhatikan bahwa metode ini kompatibel dengan UTF-16, artinya tergantung pada string input, charCodeAt dapat melampaui nilai ASCII 1 byte 1 byte jauh 0-127. Jangan menganggap itu dalam kisaran itu jika input string sewenang-wenang diterima dan ditangani oleh javascript.
theferrit32
31

Jika Anda hanya memiliki satu char dan bukan string, Anda dapat menggunakan:

'\n'.charCodeAt();

menghilangkan 0 ...

Itu lebih lambat. Dengan versi chrome saat ini, ini lebih lambat 5 kali.

Marco Altieri
sumber
10
Ini sebenarnya membutuhkan waktu lebih lama. Lebih cepat menggunakan nol saja. (Di komputer saya, butuh ~ dua kali lebih lama — 0,055 vs 0,126 melalui beberapa sepuluh ribu iterasi)
royhowie
23

Sementara jawaban lainnya benar, saya lebih suka cara ini:

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

Kemudian, untuk menggunakannya, cukup:

var lineBreak = ascii("\n");

Saya menggunakan ini untuk sistem pintas kecil:

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

Dan Anda bahkan dapat menggunakannya di dalam peta () atau metode lain:

var ints = 'ergtrer'.split('').map(ascii);
Francisco Presencia
sumber
Hanya untuk kecantikan, cara ES6 baru untuk menulisnya: const ascii = a => a.charCodeAt(0);
axkibe
20

Bagi mereka yang ingin mendapatkan jumlah semua kode ASCII untuk sebuah string:

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

Atau, ES6:

[...'Foobar']
  .map(char => char.charCodeAt(0))
  .reduce((current, previous) => previous + current)
Filip Dupanović
sumber
1
Periksa ulang baris terakhir Anda.
Ypnypn
Anggun! sebagai fungsi: function ascii (str) {return str .split ('') .map (function (char) {return char + ":" + String (char.charCodeAt (0)) + "\ n";}) .reduce (fungsi (saat ini, sebelumnya) {return current + sebelumnya;}); }
Darren Griffith
1
[...'Foobar'].reduce((i,s)=>s.charCodeAt(0)+i,0)
Nick
1
Tidak ada yang meminta jumlah semua kode ASCII dalam sebuah string, dan tidak mungkin melakukannya.
Carl Smith
8

JavaScript menyimpan string sebagai UTF-16(byte ganda) jadi jika Anda ingin mengabaikan byte kedua, hapus saja dengan &operator bitwise 0000000011111111(mis. 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
Steven de Salas
sumber
mengapa Anda ingin mengabaikan byte kedua?
Roberg
3
Pertanyaan bertanya tentang memproduksi ASCII dari string UTF-16 (byte ganda). Cepat atau lambat Anda akan mendapatkan kode non-ascii jika Anda gagal mengabaikan byte kedua.
Steven de Salas
1
@Steven de Salas - 'Solusi' Anda untuk mendapatkan kode non-ASCII untuk karakter non-ASCII adalah mengembalikan kode ASCII yang salah ??
Carl Smith
@CarlSmith, bukan yang salah. Hanya untuk menghapus komponen non-ascii dari karakter. Jika Anda bekerja dengan satu byte, ini berguna. Proyek Anda mungkin membutuhkan solusi yang berbeda.
Steven de Salas
4

Untuk memastikan dukungan Unicode dan reversibilitas penuh, pertimbangkan untuk menggunakan:

'\n'.codePointAt(0);

Ini akan memastikan bahwa ketika menguji karakter melebihi batas UTF-16, Anda akan mendapatkan nilai poin kode mereka yang sebenarnya.

misalnya

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

'𐩕'.charCodeAt(0);  // 55298
String.fromCharCode(55298);  // '�'
Ibrahim Lawal
sumber
Mungkin juga berguna untuk mengubah karakter khusus menjadi notasi hex, karena beberapa editor teks mungkin tidak berfungsi dengan baik karena harus berhadapan langsung dengan karakter tersebut. EG: lansiran (str.hexEncode (). HexDecode ());
Jose Tepedino
2

Anda dapat memasukkan karakter dan mendapatkan Kode Ascii Menggunakan Kode ini

Misalnya Masukkan Karakter Seperti A Anda Mendapatkan Kode 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>

Keshav Gera
sumber