JavaScript를 사용하여 문자를 ASCII 코드로 변환하려면 어떻게해야합니까?
예를 들면 다음과 같습니다.
“\ n”에서 10을 얻습니다.
답변
"\n".charCodeAt(0);
답변
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": ""
}
답변
문자열이 아닌 문자가 하나만 있으면 다음을 사용할 수 있습니다.
'\n'.charCodeAt();
0을 생략하고 …
그래도 느립니다. 현재 크롬 버전에서는 5 배 느립니다.
답변
다른 답변은 옳지 만 다음과 같이 선호합니다.
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);
답변
문자열에 대한 모든 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)
답변
JavaScript는 문자열을 UTF-16
(이중 바이트) 로 저장 하므로 두 번째 바이트를 무시하려면 비트 &
연산자를 사용하여 문자열을 제거하십시오 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
답변
완전한 유니 코드 지원 및 가역성을 보장하려면 다음을 사용하십시오.
'\n'.codePointAt(0);
이렇게하면 UTF-16 제한을 초과하는 문자를 테스트 할 때 실제 코드 포인트 값을 얻을 수 있습니다.
예 :
'?'.codePointAt(0); // 68181
String.fromCodePoint(68181); // '?'
'?'.charCodeAt(0); // 55298
String.fromCharCode(55298); // '�'