1

注意点

  • 值得注意的是,在js中,单引号和双引号都可以表示字符串。而且,在单引号字符串的内部,可以直接使用双引号;双引号字符串的内部,可以直接使用单引号。
'key = "value"'
"It's a long journey"

但是,若要在单引号字符串的内部,使用单引号,就必须在内部的单引号前面加上反斜杠,用来转义。双引号字符串内部使用双引号,也是如此。

'Did she say \'Hello\'?'
// "Did she say 'Hello'?"

"Did she say \"Hello\"?"
// "Did she say "Hello"?"

在日常编程中,我们要坚持一种风格,例如总是用双引号表示字符串,而在内部使用单引号

  • 另外,字符串默认只能写在一行内,分成多行会报错。
'a
b
c'
// SyntaxError: Unexpected token ILLEGAL

若长字符串必须要分成多行,可以在每行尾部使用反斜杠。但要注意,反斜杠后边必须是换行符,而不能有空格等其他字符,否则会报错

var longString = 'Long \
long \
long \
string';

longString
// "Long long long string"

或者,我们也可以使用连接运算符(+),连接多个单行字符串。

var longString = 'Long '
  + 'long '
  + 'long '
  + 'string';

但是,上边的两种方法,输出的时候还是单行,效果与写在同一行完全类似。若想输出多行字符串,有一种利用多行注释的变通方法。

(function () { /*
line 1
line 2
line 3
*/}).toString().split('\n').slice(1, -1).join('\n')
// "line 1
// line 2
// line 3"

转义

反斜杠(\)在字符串内有特殊含义,用来表示一些特殊字符,所以又称为转义符。

需要用反斜杠转义的特殊字符,主要有下面这些。

  • \0 :null(\u0000
  • \b :后退键(\u0008
  • \f :换页符(\u000C
  • \n :换行符(\u000A
  • \r :回车键(\u000D
  • \t :制表符(\u0009
  • \v :垂直制表符(\u000B
  • \' :单引号(\u0027
  • \" :双引号(\u0022
  • \\ :反斜杠(\u005C

若字符串的正常内容之中,需要包含反斜杠,则反斜杠前面需要再加一个反斜杠,用来对自身转义。

"Prev \\ Next"
// "Prev \ Next"

字符串与数组的相同与差异

  • 相同:

可以使用数组的方括号运算符,用来返回某个位置的字符(位置编号从0开始)。

var s = 'hello';
s[0] // "h"
s[1] // "e"
s[4] // "o"

// 直接对字符串使用方括号运算符
'hello'[1] // "e"

但是,若方括号中的数字超过字符串的长度,或者方括号中根本不是数字,则返回undefined

'abc'[3] // undefined
'abc'[-1] // undefined
'abc'['x'] // undefined
  • 差异:

数组可以单独改变某个字符,字符串不可以。字符串内部的单个字符无法改变和增删,这些操作会默默的失败

var s = 'hello';

delete s[0];
s // "hello"

s[1] = 'a';
s // "hello"

s[5] = '!';
s // "hello"
  • length属性:返回字符串的长度。这里要注意的是,由于每个字符在js内部都是以16位(即2个字节)的 UTF-16 格式储存,即js的单位字符固定长度为2个字节。

但是,UTF-16 有两种长度:对于码点在U+0000U+FFFF之间的字符,长度为16位(即2个字节);对于码点在U+10000U+10FFFF之间的字符,长度为32位(即4个字节),而且前两个字节在0xD8000xDBFF之间,后两个字节在0xDC000xDFFF之间。举例来说,码点U+1D306对应的字符为?,它写成 UTF-16 就是0xD834 0xDF06

所以,js对UTF-16的支持是不完善的,对四字节的字符,会识别为两个字符。因此,length返回的字符串长度可能是不正确的

js的Base64转码方法

Base64是一种编码方法,可以将任意值转成 0~9、A~Z、a-z、+/这64个字符组成的可打印字符。使用它的主要目的,不是为了加密,而是为了不出现特殊字符,简化程序的处理。

如有时文本里包含一些不可打印的符号( ASCII 码0到31的符号都无法打印出来),这时可以使用 Base64 编码,将它们转成可以打印的字符;或者需要以文本格式传递二进制数据,那么也可以使用 Base64 编码。

js 原生提供两个 Base64 相关的方法。

  • btoa():任意值转为 Base64 编码
  • atob():Base64 编码转为原来的值
var string = 'Hello World!';
btoa(string) // "SGVsbG8gV29ybGQh"
atob('SGVsbG8gV29ybGQh') // "Hello World!"

注意,这两个方法不适合非 ASCII 码的字符,会报错。

btoa('你好') // 报错

要将非 ASCII 码字符转为 Base64 编码,必须中间插入一个转码环节,再使用这两个方法。

function b64Encode(str) {
  return btoa(encodeURIComponent(str));
}

function b64Decode(str) {
  return decodeURIComponent(atob(str));
}

b64Encode('你好') // "JUU0JUJEJUEwJUU1JUE1JUJE"
b64Decode('JUU0JUJEJUEwJUU1JUE1JUJE') // "你好"

无欲则刚
76 声望15 粉丝