JavaScript'te karakteri ASCII koduna dönüştürme


952

JavaScript kullanarak bir karakteri ASCII koduna nasıl dönüştürebilirim?

Örneğin:

"\ n" den 10 alabilirsiniz.


10
Çoğu yanıtta önerilen String.prototype.charCodeAt () yönteminin UTF-16 kod birimini (geçmiş nedenlerden dolayı tam uygun UTF-16 kodlaması bile değil ) döndüreceğini lütfen unutmayın . Yalnızca ilk 128 Unicode kod noktası ASCII karakter kodlamasıyla doğrudan eşleşir.
Álvaro González

Yanıtlar:


1448
"\n".charCodeAt(0);

658
Bunun tam tersi String.fromCharCode(10).
viam0Zah

184
Eğlenceli gerçek: 0(ilk argüman değeri) gerçekten ihtiyacınız "\n".charCodeAt()yok - sadece yapacaksınız.
Mathias Bynens

47
@MathiasBynens: ve neyse ki bu belgelenmiştir: developer.mozilla.org/en/JavaScript/Reference/Global_Objects/… . "Eğer bir sayı değilse, varsayılan olarak 0"
tokland

12
Sen aksine işaret olmalıdır String.fromCharCode( asciiNumVal ), stringInstance.charCodeAt( index )olduğunu değil sınıf dize statik yöntemi
bobobobo

26
@Mathias Bynens, Kesinlikle sıfıra ayarlıyor ama ben sadece performans üzerinde sadece ilgi testi bitti ve 0 kullanarak nispeten kötü performans **. Jsperf.com/default-to-0-vs-0/4 ** Bu sadece göreceli bir fark, her iki şekilde de çok hızlı.
wade montague

385

String.prototype.charCodeAt()dize karakterlerini ASCII sayılarına dönüştürebilir. Örneğin:

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

String.fromCharCode(10)Sayıları eşit ASCII karakterine dönüştüren zıt kullanım için. Bu işlev birden çok sayıyı kabul edebilir ve tüm karakterleri birleştirip dizeyi döndürebilir. Misal:

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

İşte hızlı bir ASCII karakter referansı:

{
"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
Daha iyi ascii referansı: en.wikipedia.org/wiki/ASCII - Bu sayfadaki tablolar için yaptığım renklendirme, neredeyse 10 yıl sonra orada kalıyor
BT

9
@theGrayFox C:\> man asciiverirBad command or file name
e2-e4

Bu yöntemlerin UTF-16 uyumlu olduğunu, yani giriş dizesine bağlı olarak charCodeAt'ın 1 bayt ASCII değerlerini 0-127 geçebileceğini unutmayın. Javascript tarafından rasgele dize girişi kabul ediliyor ve işleniyorsa, bu aralıkta olduğunu varsaymayın.
theferrit32

31

Bir dizeniz değil, yalnızca bir karakteriniz varsa şunları kullanabilirsiniz:

'\n'.charCodeAt();

0 atlanıyor ...

Yine de daha yavaş. Mevcut krom sürümü ile 5 kat daha yavaştır.


10
Bu aslında daha uzun sürüyor. Sadece sıfırı kullanmak daha hızlıdır. (Bilgisayarımda, ~ iki kat daha uzun sürdü - 0.055s ve 0.126s arasında birkaç on bin yineleme)
royhowie

23

Diğer cevaplar doğru olsa da, şu şekilde tercih ederim:

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

Ardından, kullanmak için basitçe:

var lineBreak = ascii("\n");

Bunu küçük bir kısayol sistemi için kullanıyorum:

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

Ve hatta map () veya diğer yöntemlerin içinde kullanabilirsiniz:

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

Sadece güzellik için yazmak için yeni bir ES6 yolu: const ascii = a => a.charCodeAt(0);
axkibe

20

Bir dize için tüm ASCII kodlarının toplamını almak isteyenler için:

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

Veya, ES6:

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

1
Son satırınızı iki kez kontrol edin.
Ypnypn

Zarif! işlev olarak: işlev ascii (str) {return str .split ('') .map (function (char) {return char + ":" + String (char.charCodeAt (0)) + "\ n";}) .reduce (işlev (akım, önceki) {dönüş akımı + önceki;}); }
Darren Griffith

1
[...'Foobar'].reduce((i,s)=>s.charCodeAt(0)+i,0)
Nick

1
Kimse bir dizideki tüm ASCII kodlarının toplamını istemedi ve bunu yapması pek mümkün değil.
Carl Smith

Bunun için teşekkürler !!
Vinicius de Castro

8

JavaScript dizeleri UTF-16(çift bayt) olarak saklar, bu nedenle ikinci baytı göz ardı etmek istiyorsanız, sadece bitsel bir &operatörle 0000000011111111(yani 255) çıkarın :

'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

neden ikinci baytı görmezden gelmek istersiniz?
17'de Roberg

3
Soru, UTF-16 dizesinden (çift bayt) ASCII üretilmesini sormak. Er ya da geç ikinci baytı görmezden gelirseniz ascii olmayan kodlar alırsınız.
Steven de Salas

1
@Steven de Salas - ASCII olmayan karakterler için ASCII olmayan kodlar almak için 'çözüm' yanlış ASCII kodu döndürmek için ??
Carl Smith

@CarlSmith, yanlış değil. Sadece karakterin ascii olmayan bileşenini çıkarmak için. Tek bayt ile çalışıyorsanız bu yararlıdır. Ancak projenizin farklı bir çözüme ihtiyacı olabilir.
Steven de Salas

4

Tam Unicode desteği ve geri döndürülebilirliği sağlamak için aşağıdakileri kullanmayı düşünün:

'\n'.codePointAt(0);

Bu, karakterleri UTF-16 sınırı üzerinde test ederken, gerçek kod noktası değerini elde etmenizi sağlayacaktır.

Örneğin

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

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

Bazı metin editörleri doğrudan bu karakterlerle uğraşmak zorunda kalmayabileceğinden, özel karakteri onaltılı gösterime dönüştürmek de yararlı olabilir. EG: uyarı (str.hexEncode (). HexDecode ());
Jose Tepedino

2

Bu Kodu Kullanarak Bir Karakter Girebilir ve Ascii Kodunu Alabilirsiniz

Örneğin Ascii Kodunu Aldığınız gibi bir karakter girin 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>


Sitemizi kullandığınızda şunları okuyup anladığınızı kabul etmiş olursunuz: Çerez Politikası ve Gizlilik Politikası.
Licensed under cc by-sa 3.0 with attribution required.