乐趣区

关于javascript:js字符串方法汇总

字符串办法

String 类型为 根本类型 ,对其的增删改查都 不扭转原字符串,返回一个新字符串再进行操作

提取

substring(index1,index2)
substr(start,length)
slice(start,end)
split(str)

substring(index1,index2)

let s = "Hello World"
s.substring() //Hello World
s.substring(5) // World
s.substring(3, -5) //Hel
  • 没有参数:返回原字符串
  • 一个参数:作为起始下标,完结默认为字符串长度
  • 两个参数 主动比拟 辨别起始与完结
  • 正数:疏忽或按索引 0 解决
  • 提取的字符串 包头不包尾

substr(start,length)

let s = "Hello World"
s.substr(3,1) //l
s.substr(-3, 2) //rl
  • 0 个参数:与 substring 性能一样
  • 1 个参数:反对正数为起始索引
  • 两个参数:第一个为起始,第二个为长度
  • 正数 start 反对正数,- 1 为最初一个字符,length 为正数时返回空字符串

slice(start,end)

let s = "Hello World"
s.slice(3, -6) //lo
  • 0、1 个参数 与 substr 雷同
  • 两个参数 :start 与 end 均反对正数,但 end 的地位不能在 start 前,否则返回空字符串

split(str)

let s = "Hello World"
s.split() //["Hello World"]
s.split('l') //["He","","o Wor","d"]
  • 将字符串转化为 数组
  • 以子串或空字符串为 分隔,划分为多个子串,将这些子串放入数组,并返回该数组

搜寻

indexOf(str,start)
lastIndexOf(str,start)
startsWinth(str)
endsWith(str)
includes(str)
charAt(index)
charCodeAt(index)
codePointAt(index)

indexOf(str,start)

let s = "Hello World"
s.indexOf() //-1
s.indexOf("l") //2
s.indexOf("l", 6) //9
  • 无参数或者不存在子串,返回-1
  • 两个参数 :start 为 正数 时疏忽或默认为 0,空字符串 返回 start

lastIndexOf(str,start)

let s = "Hello World"
s.lastIndexOf("l") //9
s.lastIndexOf("l", 4) //3
  • 反向检索,返回第一个匹配的下标
  • 正数根本无奈应用

startsWith(str) endsWith(str)

let s = "Hello World"
s.startsWith() //false
s.startsWith("") //true
s.startsWith("H") //true
  • 检测是否以某子串结尾或结尾,返回 true/false
  • 空字符串 返回true

includes(str)

let s = "Hello World"
s.includes() //false
s.includes("") //true
s.includes("ll") //true
  • 检测是否蕴含子串,返回 true/false
  • 空字符串返回 true

charAt(index)

let s = "Hello World"
s.charAt() //H
s.charAt(0) //H 
  • 检索字符串中某下标下的字符
  • 默认为 0,正数或者超出长度返回空字符串

charCodeAt(index) codePointAt(index)

let s1 = "Hello World"
s1.charCodeAt() //72
s1.charCodeAt(0) //72
let s2 = "𠮷"
s.charCodeAt() //55362
s.codePointAt()//134071
  • 返回指定地位的字符的 Unicode 编码
  • 默认为 0,正数或超出返回NaN
  • charCodeAt 返回 0 – 65535 两个字节
  • codePointAt 能返回四个字节的码点

批改

replace(str1,str2)
toLowerCase()
toUpperCase()
trim()
trimStart()
trimEnd()
padStart(length,str)
padEnd(length,str)
normalize(“NFC/NFD/NFKC/NFKD”)

replace(str1,str2)

let s = "Hello World"
s.replace() //Hello World
s.replace("World", "JS") //Hello JS
  • 将字符串中的子串替换为其余字符串
  • str1 不是原字符串的子串时,返回原字符串

toLowerCase() toUpperCase()

let s = "Hello World"
s.toLowerCase() //hello world
s.toUpperCase() //HELLO WORLD
  • 切换大小写

trim() trimStart() trimEnd()

let s = "Hello World"
s.trim() //"Hello World"
s.trimStart()//"Hello World"
s.trimEnd() //"Hello World"
  • 删除两侧空格

padStart(length,str) padEnd(length,str)

let s = "Hello World"
s.padStart() //Hello World
s.padStart(s.length,"*") //Hello World
s.padStart(s.length+2,"*") //**Hello World
  • 在字符串的结尾或结尾填充字符串以达到指定长度
  • 指定长度须要大于原字符串长度
  • 当填充字符串过长,其长度与原字符串长度加和大于指定长度,则只填充一部分

normalize(“NFC/NFD/NFKC/NFKD”)

let s = "\u00F1"
s.normalize() //ñ
  • 依照指定的一种 Unicode 正规模式将以后字符串正规化,默认为 NFC

拼接

concat(str)
repeat(times)

concat(str)

let s = "Hello World"
let arr = ["1", "2"]
console.log(s.concat(arr)); //Hello World1,2
  • 将 str 拼接到 s 上,如果 str 不是字符串先转换成字符串再拼接

repeat(times)

let s = "Hello World"
s.repeat() //""
s.repeat(2)//Hello WorldHello World
  • 无参数或参数为 0 返回空字符串
  • times 为小数时,向下取整
退出移动版