ES5/String

字符串的常用方法

  • 我们操作字符串,也有一堆的方法来帮助我们操作

  • 字符串和数组有一个一样的地方,也是按照索引来排列的

  • charAtcharCodeAtindexOflastIndexOfsubstringsubstrsplitreplacetoLowewrCasetoUpperCase

    1. charAt()是找到字符串中指定索引位置把内容返回,如果没有对应的索引,那么就会返回 空字符串

      1
      2
      3
      var str = 'HJ'
      var res1 = str.charAt(1) // J
      var res2 = str.charAt(3) // ''
    2. charCodeAt()就是返回对应索引位置的 unicode 编码

      1
      2
      3
      var str = 'HJ'
      var res = str.charCodeAt(1) // 74
      // 因为 `J` 在 `unicode` 对照表里面存储的是 74,所以就会返回 74
    3. indexOf()就是按照字符找到对应的索引,找不到返回 -1

      1
      2
      3
      var str = 'HJ'
      var index = str.indexOf('J') // 1
      var index = str.indexOf('K') // -1
    4. substring是用来截取字符串使用的

      • 语法: substring(从哪个索引开始,到哪个索引截止),包含开始索引,不包含结束索引
      1
      2
      3
      4
      var str = 'javascript'
      var res1 = str.substring(0) // 'javascript'
      var res2 = str.substring(4) // 'script'
      var res2 = str.substring(0, 4) // 'java'
    5. substr也是用来截取字符串的

      • 语法:substr(从哪个索引开始,截取多少个)
      1
      2
      3
      var str = 'javascript'
      var res = str.substr(0) // "javascript"
      var res = str.substr(0, 4) // "java"
    6. split将字符串分割成数组

      1
      2
      3
      var name = "娄豪杰"
      var res1 = name.split() // ['娄豪杰']
      var res2 = name.split('') // ['娄', '豪', '杰']
    7. replace字符串替换

      1
      2
      var str = '666555666'
      var res = str.replace('666', '444') // "444555666"
    8. toLowewrCase字符串转成小写字母

      1
      2
      var str = "LOUHAOJIE"
      let res = str.toLowewrCase() // "louhaojie"
    9. toUpperCase字符串转成大写字母

      1
      2
      var str = "louhaojie"
      let res = str.toUpperCase() // "LOUHAOJIE"

严格模式(了解)

  • 我们都知道 js 是一个相对不很严谨的语言
  • 而且开发的时候,一些代码也不是很严格要求
  • 而严格模式就是对开发的时候写的一些内容做了要求

开启严格模式

  • 想开启严格模式,直接在代码最开始的位置写上字符串 use strict

    1
    2
    3
    4
    <script>
    "use strtic";
    // 下面代码书写就要按照严格模式来书写
    </script>

严格模式的规则

  1. 声明变量必须有 var 关键字

    1
    2
    3
    4
    "use strtic";

    num = 200; // 这个就会报错
    var num = 200; // 正确写发放
    • 之前了解过,在声明变量的时候,如果没有 var 关键字,那么按照作用域的规则会自动定义成全局变量
    • 严格模式下不可以,会报错
  2. 函数的行参不可以重复

    1
    2
    3
    "use strtic";

    function fn(p1, p1) {} // 直接就会报错
    • 在非严格模式下,函数两个行参一样,是不会报错的,只不过就是相当于在函数内部只有一个变量了
    • 但是在严格模式下会报错
  3. 声明式函数调用的时候函数内部没有 this

    1
    2
    3
    4
    5
    6
    "use strtic";

    function fn() {
    console.log(this); // undefined
    }
    fn();
    • 本身,全局声明式函数在调用的时候,函数内部的 this 是指向 window
    • 在严格模式下,是没有 this

ASCII 字符集(了解)

  • 我们都知道,计算机只能存储 0101010 这样的二进制数字
  • 那么我们的 a ~ z / A ~ Z / $ / @ /… 之类的内容也有由二进制数字组成的
  • 我们可以简单的理解为, a ~ z / A ~ Z / $ / @ /… 之类的内容都有一个自己的编号,然后在计算机存储的时候,是存储的这些编号,我们看的时候,也是通过这些编号在解析成我们要看到的内容给我们看到

unicode 编码

  • 我们看到了,ASCII 只有这 128 个字符的编码结构
  • 但是因为 ASCII 出现的比较早,而且是美国发明的,早先时候这些内容就够用了
  • 因为存储一些英文的内容,传递一些英文的文章什么的都够用了
  • 那么对于这个世界来说肯定是不够用的
  • 因为我们的汉字没有办法存储,包括一些其他国家的语言也没有办法存储
  • 所以就出现了 unicode 编码,也叫(万国码,统一码)
  • unicode 对照表就是一个和 ASCII 一样的对照表,只不过变得很大很大,因为存储的内容特别的多
  • 而且包含了世界上大部分国家的文字,所以我们的文字和字符现在在存储的时候,都是按照 unicode 编码转换成数字进行存储
  • 我们的 UTF-8 就是一种 8 位的 unicode 字符集