[js] charAt()、charCodeAt()、fromCharCode()
String.prototype.charAt()
str.charAt(index)
返回字符串中指定位置的字符。
字符串中的字符从左向右索引,第一个字符的索引值为 0,最后一个字符(假设该字符位于字符串 stringName 中)的索引值为 stringName.length - 1。
如果指定的 index 值超出了该范围,则返回一个空字符串。
var anyString = "Brave new world"; console.log("The character at index 0 is '" + anyString.charAt(0) + "'"); console.log("The character at index 1 is '" + anyString.charAt(1) + "'"); console.log("The character at index 2 is '" + anyString.charAt(2) + "'"); console.log("The character at index 3 is '" + anyString.charAt(3) + "'"); console.log("The character at index 4 is '" + anyString.charAt(4) + "'"); console.log("The character at index 999 is '" + anyString.charAt(999) + "'"); // The character at index 0 is 'B' // The character at index 1 is 'r' // The character at index 2 is 'a' // The character at index 3 is 'v' // The character at index 4 is 'e' // The character at index 999 is ''
String.prototype.charCodeAt()
str.charCodeAt(index)
返回指定索引处字符的 Unicode 数值(Unicode 编码单元 > 0x10000 的除外)。
Unicode 编码单元(code points)的范围从 0 到 1,114,111。开头的 128 个 Unicode 编码单元和 ASCII 字符编码一样。
如果指定的 index 小于 0 或大于字符串的长度,则 charCodeAt 返回 NaN。
大于255为中文
"ABC".charCodeAt(0) // returns 65
//求一个字符串的字节长度 function GetBytes(str) { var len = str.length; var bytes = len; for (var i = 0; i < len; i++) { //console.log(str[i],str.charCodeAt(i)); if (str.charCodeAt(i) > 255) bytes++; } return bytes; } console.log(GetBytes("你好,as"));
String.fromCharCode()
String.fromCharCode(num1, ..., numN)
String.fromCharCode() 静态方法根据指定的 Unicode 编码中的序号值来返回一个字符串。
String.fromCharCode(65,66,67) //"ABC"
#字母 <-> ASCII <-> 十六进制
var Converter = (function() { var $ = {}; $.toAscii = function(hex) { var temp = ''; for (var i = 0; i < hex.length; i = i + 2) { temp += String.fromCharCode(parseInt(hex.slice(i, i + 2), 16)); } return temp; } $.toHex = function(ascii) { var temp = ''; for (var i = 0; i < ascii.length; i++) { temp += ascii.charCodeAt(i).toString(16); } return temp; } return $; })();