ฉันจะแปลงอักขระเป็นรหัส ASCII โดยใช้ JavaScript ได้อย่างไร
ตัวอย่างเช่น:
รับ 10 จาก "\ n"
ฉันจะแปลงอักขระเป็นรหัส ASCII โดยใช้ JavaScript ได้อย่างไร
ตัวอย่างเช่น:
รับ 10 จาก "\ n"
คำตอบ:
"\n".charCodeAt(0);
String.fromCharCode(10)
ตรงข้ามของที่นี่คือ
0
(ค่าอาร์กิวเมนต์แรก) - "\n".charCodeAt()
จะทำ
String.fromCharCode( asciiNumVal )
, stringInstance.charCodeAt( index )
คือไม่ได้เป็นวิธีการที่คงที่ของคลาส String
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": ""
}
C:\> man ascii
ให้Bad command or file name
หากคุณมีเพียงถ่านเดียวและไม่ใช่สตริงคุณสามารถใช้:
'\n'.charCodeAt();
ละเว้น 0 ...
มันช้ากว่าแม้ว่า ด้วย Chrome รุ่นปัจจุบันมันช้ากว่า 5 เท่า
ในขณะที่คำตอบอื่น ๆ ถูกต้องฉันชอบวิธีนี้:
function ascii (a) { return a.charCodeAt(0); }
จากนั้นเพื่อใช้งานเพียง:
var lineBreak = ascii("\n");
ฉันใช้สิ่งนี้กับระบบทางลัดขนาดเล็ก:
$(window).keypress(function(event) {
if (event.ctrlKey && event.which == ascii("s")) {
savecontent();
}
// ...
});
และคุณยังสามารถใช้ภายในแผนที่ () หรือวิธีอื่น ๆ :
var ints = 'ergtrer'.split('').map(ascii);
const ascii = a => a.charCodeAt(0);
สำหรับผู้ที่ต้องการรับผลรวมของรหัส 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)
[...'Foobar'].reduce((i,s)=>s.charCodeAt(0)+i,0)
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
เพื่อให้การสนับสนุน Unicode เต็มรูปแบบและความสามารถในการกลับรายการได้ให้พิจารณาใช้
'\n'.codePointAt(0);
สิ่งนี้จะช่วยให้มั่นใจได้ว่าเมื่อทดสอบอักขระเกินขีด จำกัด UTF-16 คุณจะได้รับค่ารหัสจุดจริง
เช่น
'𐩕'.codePointAt(0); // 68181
String.fromCodePoint(68181); // '𐩕'
'𐩕'.charCodeAt(0); // 55298
String.fromCharCode(55298); // '�'
คุณสามารถป้อนตัวอักษรและรับรหัส Ascii โดยใช้รหัสนี้
ตัวอย่างเช่นป้อนตัวละครอย่างคุณได้รับรหัส 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>
สำหรับการสนับสนุนทุก UTF-16 (ยังไม่ใช่ BMP / ตัวละครเสริม ) จาก ES6 string.codePointAt ()เป็นวิธีการที่สามารถใช้ได้;
วิธีการนี้เป็นรุ่นที่ปรับปรุงแล้วของ charCodeAt ซึ่งสามารถรองรับการเข้ารหัสรหัส unicode <65536 (2 16 - 16 บิตเดียว)
String.prototype.codePointAt()
จะไม่สนับสนุนใด ๆรุ่นของ Internet Explorer ( แต่จะได้รับการสนับสนุนบนขอบ.) คุณจะได้รับ polyfill ที่นี่