• JavaScript的字符串就是用’’或””括起来的字符表示。
  • 如果’本身也是一个字符,那就可以用””括起来,比如”I’m OK”包含的字符是I,’,m,空格,O,K这6个字符。

    转义字符\

  • 如果字符串内部既包含’又包含”怎么办?可以用转义字符\来标识,比如:

  • 'I\'m \"OK\"!'; // 表示的字符串内容是:I'm "OK"!

    多行字符串

  • 由于多行字符串用\n写起来比较费事,所以最新的ES6标准新增了一种多行字符串的表示方法,用反引号...表示:

    1. `这是一个
    2. 多行
    3. 字符串`;

    模板字符串

  • 要把多个字符串连接起来,可以用+号连接

    1. var name = '小明';
    2. var age = 20;
    3. var message = '你好, ' + name + ', 你今年' + age + '岁了!';
    4. alert(message);
  • 如果有很多变量需要连接,用+号就比较麻烦。ES6新增了一种模板字符串, 表示方法和上面的多行字符串一样,但是它会自动替换字符串中的变量:

    1. var name = '小明';
    2. var age = 20;
    3. var message = `你好, ${name}, 你今年${age}岁了!`;
    4. alert(message);

    操作字符串

    ```javascript var s = ‘Hello, world!’;

s.length; // 13 s[0]; // ‘H’ s[6]; // ‘ ‘ s[7]; // ‘w’ s[12]; // ‘!’ s[13]; // undefined 超出范围的索引不会报错,但一律返回undefined

  1. 字符串是不可变的,如果对字符串的某个索引赋值,不会有任何错误,但是,也没有任何效果:
  2. ```javascript
  3. var s = 'Test';
  4. s[0] = 'X';
  5. alert(s); // s仍然为'Test'

常用方法

  • JavaScript为字符串提供了一些常用方法,注意,调用这些方法本身不会改变原有字符串的内容,而是返回一个新字符串:

    toUpperCase

  • toUpperCase()把一个字符串全部变为大写: ```javascript var s = ‘Hello’; s.toUpperCase(); // 返回’HELLO’

  1. <a name="PuYIb"></a>
  2. ### toLowerCase
  3. - toLowerCase()把一个字符串全部变为小写:
  4. ```javascript
  5. var s = 'Hello';
  6. var lower = s.toLowerCase(); // 返回'hello'并赋值给变量lower
  7. lower; // 'hello'

indexOf

  • indexOf()会搜索指定字符串出现的位置
    ```javascript var s = ‘hello, world’; s.indexOf(‘world’); // 返回7 s.indexOf(‘World’); // 没有找到指定的子串,返回-1
  1. <a name="bc676"></a>
  2. ### substring
  3. - substring()返回指定索引区间的子串:
  4. ```javascript
  5. var s = 'hello, world'
  6. s.substring(0, 5); // 从索引0开始到5(不包括5),返回'hello'
  7. s.substring(7); // 从索引7开始到结束,返回'world'