1. 基本包装类型

Snipaste_2021-09-27_01-10-58.png

  1. <script>
  2. // 基本包装类型
  3. var str = 'andy';
  4. console.log(str.length);//4
  5. // 对象 才有 属性和方法 复杂数据类型才有 属性和方法
  6. // 简单数据类型为什么会有length 属性呢?
  7. // 基本包装类型: 就是把简单数据类型 包装成为了 复杂数据类型
  8. // (1) 把简单数据类型包装为复杂数据类型
  9. var temp = new String('andy');
  10. // (2) 把临时变量的值 给 str
  11. str = temp;
  12. // (3) 销毁这个临时变量
  13. temp = null;
  14. </script>

2. 字符串的不可变性

Snipaste_2021-09-27_01-18-55.png
Snipaste_2021-09-27_23-59-28.png

  1. <script>
  2. // 字符串的不可变性
  3. var str = 'andy';
  4. console.log(str);
  5. str = 'red';
  6. console.log(str);
  7. // 因为我们字符串的不可变所以不要大量的拼接字符串
  8. var str = '';
  9. for (var i = 1; i <= 1000000; i++) {
  10. str += i;
  11. }
  12. console.log(str);
  13. </script>

3. 根据字符返回位置

Snipaste_2021-09-27_01-27-29.png

  1. <script>
  2. // 字符串对象 根据字符返回位置 str.indexOf('要查找的字符', [起始的位置])
  3. var str = '改革春风吹满地,春天来了';
  4. console.log(str.indexOf('春'));//2
  5. console.log(str.indexOf('春', 3));//8 // 从索引号是 3的位置开始往后查找
  6. </script>

案例:返回字符位置

Snipaste_2021-09-27_19-46-17.png
Snipaste_2021-09-27_19-46-35.png

查找字符串中某个字符出现的次数

  1. <script>
  2. // 查找字符串"abcoefoxyozzopp"中所有o出现的位置以及次数
  3. // 核心算法:先查找第一个o出现的位置
  4. // 然后 只要indexOf 返回的结果不是 -1 就继续往后查找
  5. // 因为indexOf 只能查找到第一个,所以后面的查找,一定是当前索引加1,从而继续查找
  6. var str = "oabcoefoxyozzopp";
  7. var index = str.indexOf('o');
  8. var num = 0;
  9. // console.log(index);
  10. while (index !== -1) {
  11. console.log(index);//0 4 7 10 13
  12. num++;
  13. index = str.indexOf('o', index + 1);
  14. }
  15. console.log('o出现的次数是: ' + num);//o出现的次数是: 5
  16. // 课后作业 ['red', 'blue', 'red', 'green', 'pink','red'], 求 red 出现的位置和次数
  17. </script>

4. 根据位置返回字符

Snipaste_2021-09-27_19-59-02.png

ASCII值 目的: 判断用户按下了那个键

Snipaste_2021-09-27_20-03-47.png

  1. <script>
  2. // 根据位置返回字符
  3. // 1. charAt(index) 根据位置返回字符
  4. var str = 'andy';
  5. console.log(str.charAt(3));//y
  6. // 遍历所有的字符
  7. for (var i = 0; i < str.length; i++) {
  8. console.log(str.charAt(i));//a n d y
  9. }
  10. // 2. charCodeAt(index) 返回相应索引号的字符ASCII值 目的: 判断用户按下了那个键
  11. console.log(str.charCodeAt(0)); // 97
  12. // 3. str[index] H5 新增的
  13. console.log(str[0]); // a
  14. </script>

案例:返回字符位置

Snipaste_2021-09-27_20-09-40.png
Snipaste_2021-09-27_20-09-54.png

统计出现最多的字符和次数

  1. <script>
  2. // 有一个对象 来判断是否有该属性 对象['属性名']
  3. var o = {
  4. age: 18
  5. }
  6. if (o['sex']) {
  7. console.log('里面有该属性');
  8. } else {
  9. console.log('没有该属性');
  10. }
  11. // 判断一个字符串 'abcoefoxyozzopp' 中出现次数最多的字符,并统计其次数。
  12. // o.a = 1
  13. // o.b = 1
  14. // o.c = 1
  15. // o.o = 4
  16. // 核心算法:利用 charAt() 遍历这个字符串
  17. // 把每个字符都存储给对象, 如果对象没有该属性,就为1,如果存在了就 +1
  18. // 遍历对象,得到最大值和该字符
  19. var str = 'abcoefoxyozzopp';
  20. var o = {};
  21. for (var i = 0; i < str.length; i++) {
  22. var chars = str.charAt(i); // chars 是 字符串的每一个字符
  23. if (o[chars]) { // o[chars] 得到的是属性值
  24. o[chars]++;
  25. } else {
  26. o[chars] = 1;
  27. }
  28. }
  29. console.log(o);
  30. // 2. 遍历对象
  31. var max = 0;
  32. var ch = '';
  33. for (var k in o) {
  34. // k 得到是 属性名
  35. // o[k] 得到的是属性值
  36. if (o[k] > max) {
  37. max = o[k];
  38. ch = k;
  39. }
  40. }
  41. console.log(max);//4
  42. console.log('最多的字符是' + ch);//最多的字符是o
  43. </script>

5. 字符串操作方法(重点)

Snipaste_2021-09-27_20-32-13.png

拼接以及截取字符串

  1. <script>
  2. // 字符串操作方法
  3. // 1. concat('字符串1','字符串2'....)
  4. var str = 'andy';
  5. console.log(str.concat('red'));//andyred
  6. // 2. substr('截取的起始位置', '截取几个字符');
  7. var str1 = '改革春风吹满地';
  8. console.log(str1.substr(2, 2));//春风 // 第一个2 是索引号的2 从第几个开始 第二个2 是取几个字符
  9. </script>

6. 其他方法

Snipaste_2021-09-27_20-41-09.png
Snipaste_2021-09-27_20-41-28.png

  1. <script>
  2. // 1. 替换字符 replace('被替换的字符', '替换为的字符') 它只会替换第一个字符
  3. var str = 'andyandy';
  4. console.log(str.replace('a', 'b'));//bndyandy
  5. // 有一个字符串 'abcoefoxyozzopp' 要求把里面所有的 o 替换为 *
  6. var str1 = 'abcoefoxyozzopp';
  7. while (str1.indexOf('o') !== -1) {
  8. str1 = str1.replace('o', '*');
  9. }
  10. console.log(str1);//abc*ef*xy*zz*pp
  11. // 2. 字符转换为数组 split('分隔符') 前面我们学过 join 把数组转换为字符串
  12. var str2 = 'red, pink, blue';
  13. console.log(str2.split(','));// ['red', ' pink', ' blue']
  14. var str3 = 'red&pink&blue';
  15. console.log(str3.split('&'));// ['red', ' pink', ' blue']
  16. </script>

7. toUpperCase()转换大写 与 toLowerCase()转换小写

Snipaste_2021-09-27_20-53-43.png

作业

Snipaste_2021-09-27_20-58-03.png