字符的理解和15种使用方法

98 阅读6分钟

字符的理解和15种使用方法

-   ECMAScript版本5,是公认兼容性最好的版本

    -   将来做好的项目,代码要转成ES5去运行

-   严格模式

    -   对代码要求更高

        -   在全局的顶部或局部的顶部添加字符串 'use strict'

            -   添加在全局的,可以要求所有代码
            -   添加在局部的,只能要求局部的代码

    -   优点

        -   代码更加规范
        -   运行的效率更高了
  • 重新认识

    • 字符串可以取下标,能遍历

    • 只能读,不能增、删、改

    • 字符串有长度

      • 字符串.length

字符串比较

  • 字符串可以比较大小,比较规则是 逐字符比较

    • 字符大小由阿斯克码决定

      • 0-9的阿斯克码

        • 48~57
      • A-Z的阿斯克码

        • 65~90
      • a-z的阿斯克码

        • 97~122

字符串方法

  • charAt:根据下标获取对应的字符

    语法:字符串.charAt(下标) - 返回对应的字符

    ini
     var str = 'abcdef'
     console.log( str.charAt(3) );
     console.log( str[3] );
    
  • charCodeAt - 根据指定下标获取对应的字符的阿斯克码

    语法:字符串.charCodeAt(下标) - 返回阿斯克码

    ini
    var str = 'abcdef';
    // 获取下标为3的字符的阿斯克码
    var res = str.charCodeAt(0); // 参数为指定的下标
    console.log(res); // 97
    
  • String.fromCharCode - 根据指定的阿斯克码得到对应的字符

    语法:String.fromCharCode(阿斯克码) - 返回对应的字符

    javascript
    // 获取98对应的字符
    var res = String.fromCharCode(98); // 参数为指定的阿斯克码
    console.log(res); // b
    
  • indexOf - 查找字符或子字符串在大字符串中第一次出现的位置

    语法:字符串.indexOf(字符或小字符串)

    javascript
    var str = 'i love you';
    // 找到o字符在str中第一次出现的位置
    var s = str.indexOf('o'); // 参数为要查找的字符
    console.log(s); // 3var s = str.indexOf('o',4); // 参数2为开始查找的下标
    console.log(s) // 8var s = str.indexOf('a') // 查找a字符在字符串中第一次出现的下标
    console.log(s) // -1 - 找不到就返回-1
    
  • lastIndexOf - 查找字符在字符串中最后一次出现的下标

    语法:字符串.lastIndexOf(字符/小字符串)

    javascript
    var str = 'i love you';
    // 找到o字符在str中最后一次出现的位置
    var s = str.lastIndexOf('o');
    console.log(s); // 8var s = str.lastIndexOf('o',7) // 将下标7当做字符串末尾,查找字符o在字符串中最后一次出现的下标
    console.log(s) // 3var s = str.lastIndexOf('a')
    console.log(s) // -1 - 找不到就返回-1
    
  • slice - 截取字符串

    语法:字符串.slice(开始下标, 结束下标) - 返回截取出来一段字符串

    javascript
    var str = 'abcdef';
    // 从下标1截取到下标4
    var s = str.slice(1,4) // 参数1是开始截取的下标,参数2是截取的结束下标
    console.log(s) // bcd - 结果中不包含结束下标对应的字符var s = str.slice(1) // 省略第二个参数,默认能截取到字符串末尾
    console.log(s) // bcdefvar s = str.slice(-3,-1) // 下标可以使用负数表示,-3表示倒数第3个字符,-1表示倒数第1个字符
    console.log(s) // defvar s = str.slice(-1,-3) // 如果开始下标比结束下标大,会截取到空
    console.log(s) // ''
    
  • split - 将字符串使用指定的分隔符分割为数组

    语法:字符串.split(分隔符) - 返回数组

    css
    var str = 'a-b-c-d';
    var arr = str.split('-') // 参数为分隔符,使用-将字符串分割为一个数组
    console.log(arr) // ['a','b','c','d']var arr = str.split('-',3) // 参数2表示数组中要保留前几个元素
    console.log(arr) // ['a','b','c']var str = 'abcd';
    var arr = str.split() // 省略了分隔符,默认就不分割,将整个字符串当做一个元素放在数组中
    console.log(arr) // ['abcd']var arr = str.split('')
    console.log(arr) // ["a", "b", "c", "d"]
    
  • replace - 使用新字符串将字符串中某一部分替换掉

    语法:字符串.replace(字符串中的一部分, 新内容) - 返回被替换后的字符串

    python
    var str = '你的头发还好吗?';
    str = str.replace('头发','眉毛') // 参数1是被替换的字符串中的部分,参数2是新内容
    console.log(str) // '你的眉毛还好吗?'str = str.replace('','哈哈') // 参数1为空,就会将新内容添加到原字符串的最前面
    console.log(str) // '哈哈你的眉毛还好吗?'
    
  • trim - 去除字符串两端空白

    语法:字符串.trim() - 返回左右两边没有空格字符串

    ini
    var str = '    aaa          ';
    str = str.trim()
    console.log(str) // 'aaa' - 左右两端的空白被去掉了
    
  • trimLeft:去除左边空格

rust
  str = str.trimLeft() // 去除左边的空白
  console.log(str) // 'aaa   
  • trimRight:去除右边空格
rust
   str = str.trimRight() // 去除右边的空白
   console.log(str) // '    aaa'
  • toUpperCase - 将字符串中字母转为大写

    语法:字符串.toUpperCase()

    ini
    var str = 'i love you';
    str = str.toUpperCase()
    console.log(str) // 'I LOVE YOU'
    
  • toLowerCase - 将字符串中字母转为小写

    语法:字符串.toLowerCase()

    ini
    var str = 'I LOVE YOU';
    str = str.toLowerCase()
    console.log(str) // 'i love you'
    
  • substr - 截取字符串

    语法:字符串.substr(开始下标, 截取的长度) - 返回截取出来的一段

    rust
    var str = 'abcdef';
    str = str.substr(1,3) // 参数1是开始截取的下标,参数2是截取的字符串长度
    console.log(str) // bcdstr = str.substr(1) // 省略参数2默认截取到字符串末尾
    console.log(str) // bcdefstr = str.substr(-4,2) // 开始截取的下标可以用负数表示
    console.log(str) // 'cd'str = str.substr(1,20) // 长度超出最大下标,就相当于省略了参数2
    console.log(str) // cdef
    
  • substring - 截取字符串

    语法:字符串.substring(开始下标, 结束下标) - 返回截取出来一段字符串

    scss
    var str = 'abcdef'
    str = str.substring(1,4) // 参数1是开始截取的下标,参数2是结束下标
    console.log(str) // bcd - 结果不包含结束下标对应的字符
    ​
    str = str.substring(1) // 省略参数2,默认截取到末尾
    console.log(str) // bcdef
    ​
    str = str.substring(1,1) // 开始下标和结束下标相等就截取到空字符串
    console.log(str) // ''
    ​
    str = str.substring(4,1) // 开始下标大于结束下标,就先交换两个参数位置,然后再截取
    console.log(str) // 'bcd'
    ​
    str = str.substring(-5,4) // 开始下标或结束下标是负数,就先替换为0,然后开始截取
    console.log(str) // abcd
    
  • startsWith - 判断字符串是否以某个字符或小字符串开头

    语法:字符串.startsWith(字符/小字符串) - 返回布尔值

    ini
    var str = 'abcdef'
    var bool1 = str.startsWith('a') // true
    var bool2 = str.startsWith('ab') // true
    var bool3 = str.startsWith('aa') // false
    
  • endsWith - 判断字符串是否以某个字符或小字符串结尾

    语法:字符串.endsWith(字符/小字符串) - 返回布尔值

    ini
    var str = 'abcdef'
    var bool1 = str.endsWith ('f') // true
    var bool2 = str.endsWith ('ef') // true
    var bool3 = str.endsWith ('ff') // false
    
  • includes - 判断字符串中是否包含某个字符

    语法:字符串.includes(字符/小字符串) - 返回布尔值

    ini
    var str = 'abcdef'
    var bool1 = str.endsWith ('cd') // true
    var bool2 = str.endsWith ('f') // true
    var bool3 = str.endsWith ('acd') // false
    
  • repeat:将某个字符串重复多次,形成新的字符串

    语法:字符串.repeat(次数) - 返回新字符串

ini
var str = '*'

str = str.repeat(9)

console.log(str);