1. 字符串
-
字符串是以单引号'或双引号"括起来的任意文本,比如'abc',"xyz"等等。
-
''或""本身只是一种表示方式,不是字符串的一部分,因此,字符串'abc'只有a,b,c这3个字符。
JavaScript的字符串就是用''或""括起来的字符表示。 如果'本身也是一个字符,那就可以用""括起来,比如"I'm OK"包含的字符是I,',m,空格,O,K这6个字符。 如果字符串内部既包含'又包含" 可以用转义字符 \ 来标识'I\'m \"OK\"!'; // I'm "OK"! 转义字符\可以转义很多字符,比如\n表示换行,\t表示制表符,字符\本身也要转义,所以\\表示的字符就是\。 ASCII字符可以以\x##形式的十六进制表示,例如:'\x41'; // 完全等同于 'A'还可以用\u####表示一个Unicode字符:'\u4e2d\u6587'; // 完全等同于 '中文'
2. 多行字符串
- 标识: `` 反引号
var a = `aaaaa`
console.log(a)aaaaa
3. 模板字符串
-
把多个字符串连接起来,可以用+号连接:
let name = 'kyle'; let age = 20; var message = '你好,' + name + ',你今年' + age +'岁了' console.log(message) //你好,kyle,你今年20岁了
如果有很多变量需要连接,用+号就比较麻烦。
ES6新增了一种模板字符串,表示方法和上面的多行字符串一样,但是它会自动替换字符串中的变量:
let name = '小明'; let age = 20; let message = \`你好, ${name}, 你今年${age}岁了!`; console.log(message); //你好,小明,你今年20岁了
4. 操作字符串:
4.1 获取字符串长度:
let s = 'Hello, world!';
s.length; // 13
4.2 索引
-
要获取字符串某个指定位置的字符,使用类似Array的下标操作,索引号从0开始:
let s = 'Hello, world!'; s[0]; // 'H' s[6]; // ' ' s[7]; // 'w' s[12]; // '!' s[13]; // undefined 超出范围的索引不会报错,但一律返回undefined '特别注意的是,字符串是不可变的,如果对字符串的某个索引赋值,不会有任何错误,但是,也没有任何效果:' let s = 'Test'; s[0] = 'X';console.log(s); // s仍然为'Test'
4.3 toUpperCase
toUpperCase()把一个字符串全部变为大写:let s = 'Hello';s.toUpperCase(); // 返回'HELLO'
4.4 toLowerCase
toLowerCase()把一个字符串全部变为小写:let s = 'Hello';let lower = s.toLowerCase(); // 返回'hello'并赋值给变量lowerlower; // 'hello'
4.5 indexOf
indexOf()会搜索指定字符串出现的位置:let s = 'hello, world';s.indexOf('world'); // 返回7s.indexOf('World'); // 没有找到指定的子串,返回-1
4.6 substring
substring()返回指定索引区间的子串:let s = 'hello, world's.substring(0, 5); // 从索引0开始到5(不包括5),返回'hello's.substring(7); // 从索引7开始到结束,返回'world'
练习:
let s = 'Hello World';
var upper = s.toUpperCase();
let lower = s.toLowerCase(); // 返回'hello'并赋值给变量lower
var indexof = s.indexOf('world');
let aSubstring = s.substring(7);
console.log(upper) // HELLO WORLD
console.log(lower) // hello world
console.log(indexof) // 没找到world 返回:-1
console.log(aSubstring) //从索引7位置开始到结尾:orld