JavaScript字符串的常用方法

JavaScript字符串的常用方法

var str = "hello world";

// 表示str里面有多少个字符串
console.log(str.length); // 11

charAt

  • 作用:找到字符串指定索引位置的字符串

  • 语法:字符串.charAt(索引)

  • 返回值:找到的字符串,没找到返回""

var str = "hello world"

console.log(str.charAt(2)) // l
console.log(str.charAt(200)) // 没找到返回空字符串

charCodeAt

  • 作用:找到字符串指定索引位置的字符串编码

  • 语法:字符串.charCodeAt(索引)

  • 返回值:找到的编码,没找到返回NaN

var str = "hello world"

console.log(str.charCodeAt(1)) // 找到字母e对应的编码101
console.log(str.charCodeAt(100)) // NaN

indexOf

  • 作用::从头开始找指定字符的索引

  • 语法:字符串.indexOf(字符)

  • 返回值:字符的索引,没找到返回-1

var str = "hello world"

console.log(str.indexOf('h')) //0
console.log(str.indexOf('o')) //4
console.log(str.indexOf('A')) //-1

lastIndexOf

  • 作用:从末尾开始找指定字符的索引

  • 语法:字符串.lastIndexOf(字符)

  • 返回值:字符的索引,没找到返回-1

var str = "hello world"

console.log(str.lastIndexOf('l')) //9
console.log(str.lastIndexOf('o')) //7
console.log(str.lastIndexOf('A')) //-1

截取字符串中的一部分

slice

  • 作用:提取某个字符串的一部分

  • 语法:字符串.slice(start[,end])

    • 如果不写end表示截取到最末尾

    • 包括start,不包括end

  • 返回:一个新的字符串,且不会改动原字符串

var str = "abcde12345ABCDE"

// 不写end截取到最后
console.log(str.slice(5)) // 12345ABCDE

// 截取的内容包括start,不包括end
console.log(str.slice(0,5)) // abcde

// 不能这么写
console.log(str.slice(5,0))

// 可以识别负数,表示倒数第3个开始截取
console.log(str.slice(-3)) // CDE

substr

  • 作用:返回一个字符串中从指定位置开始到指定字符数的字符

  • 语法:字符串.substr(start[,length])

    • 如果不写length表示截取到最末尾
    • 从start索引开始截取length个字符
  • 返回:一个新的字符串,且不会改动原字符串

var str = "abcde12345ABCDE"

console.log(str.substr(1)) // bcde12345ABCDE
console.log(str.substr(1,4)) // bcde

substring

  • 作用:提取某个字符串的一部分

  • 语法:字符串.substring(start[,end])

    • 如果不写end表示截取到最末尾
    • 包括start,不包括end
  • 返回:一个新的字符串,且不会改动原字符串

var str = "abcde12345ABCDE"

console.log(str.substring(5)) // 12345ABCDE
console.log(str.substring(0,5)) // abcde

// 智能调换顺序
console.log(str.substring(5,0)) // abcde

// 全部截取
console.log(str.substring(-3)) // abcde12345ABCDE

repeat

  • 作用:重复字符串

  • 语法:字符串.repeat(重复的次数)

  • 返回值:一个新的重复好的字符串

var str = "hello world"

console.log(str.repeat(3)) // hello worldhello worldhello world

split

  • 作用:把字符串切分成数组

  • 语法:字符串.split("分隔符")

    • 不写分隔符,数组中只有一个元素
  • 返回值:一个新数组

var str = "hello world"

// 数组里面一个元素
console.log(str.split()) // ['hello world']

// 会以空格为分隔符
console.log(str.split(" ")) // ['hello', 'world']

// 会以空字符串为分隔符
console.log(str.split("")) // ['h', 'e', 'l', 'l', 'o', ' ', 'w', 'o', 'r', 'l', 'd']

toLowerCase/toUpperCase

  • 作用:字符串转小写/字符串转大写
  • 语法:
    • 字符串.toLowerCase()
    • 字符串.toUpperCase()
  • 返回值:一个新数字符串
var str = "abcde12345ABCDE"

console.log(str.toLowerCase()) // abcde12345abcde
console.log(str.toUpperCase()) // ABCDE12345ABCDE

String.fromCharCode(编码)

  • 作用:根据编码转成对应的字符串

  • 语法:String.fromCharCode(编码)

  • 返回值:编码对应的字符

console.log(String.fromCharCode(65)) //A
console.log(String.fromCharCode(101)) //e

concat()

  • 作用:将一个或多个字符串与原字符串连接合并,形成一个新的字符串并返回

  • 语法:str.concat(str2, [, ...strN])

  • 返回值:新的字符串

  • 强烈建议使用赋值操作符(+, +=)代替 concat 方法

var text1 = "Hello"
var text2 = "World"

console.log(text1.concat(" ",text2)) //Hello World

trim

  • 作用:删除字符串两端的空白符

  • 语法:str.trim()

  • 返回值::一个代表调用字符串两端去掉空白的新字符串

var str = "       Hello World!        "
console.log(str.trim()) // Hello World!

test

  • 作用:用来检测字符串是否符合正则的标准

  • 语法:正则.test(字符串)

  • 返回值:boolean

    • true:符合规则

    • false:不符合规则

var reg = /\d{3}/g
var reg2 = /^[a-zA-Z]+$/
var str = "hello123world456你好789!"

console.log(reg.test(str)) // true
console.log(reg2.test(str)) // false

exec

  • 作用:把字符串中符合正则的内容捕获出来

  • 语法:正则.exec(字符串)

  • 返回值:

    • 把字符串中符合正则的要求的第一项以及一些其他信息,以数组的形式返回

    • 未找到,则返回值为 null

var reg = /\d{3}/g;
var str = "hello123world456你好789!";

// 获取第一个符合条件的
var res = reg.exec(str);
console.log(res) // ["123"]

// 获取下一个符合条件
var res = reg.exec(str);
console.log(res) // ["456"]

// 获取下一个符合条件
var res = reg.exec(str);
console.log(res) // ["789"]

// 获取下一个符合条件
var res = reg.exec(str);
console.log(res) // null

search

  • 作用:查找字符串中是否有满足正则条件的内容

  • 语法:str.search(正则)

  • 返回值:正则表达式在字符串中首次匹配项的索引;否则,返回 -1

  • g不起作用

var str = "hello123world456你好789!"
var str2 = "hello"

var reg = /\d{3}/;
console.log(str.search(reg));//5
console.log(str2.search(reg));//-1

match

  • 作用:找到字符串中符合正则条件的内容返回

  • 语法:字符串.match(正则)

  • 返回值:

    • 有g:所有匹配的内容的集合

    • 没g:把字符串中符合正则的要求的第一项以及一些其他信息,以数组的形式返回

var str = "hello123world456你好789!"
var reg = /\d{3}/
var reg2 = /\d{3}/g

//有g
console.log(str.match(reg2))  // ["123", "456", "789"]

//没有g
console.log(str.match(reg)) // ["123"]

replace

  • 作用:是替换字符串中符合正则条件的字符

  • 语法:字符串.replace(正则,要替换成的新字符串)

  • 返回值:替换好的字符串

    • 有g:替换所有符合条件的

    • 没有g:替换第一个符合条件的

var str = "hello123world456你好789!"
var reg = /\d{3}/
var reg2 = /\d{3}/g

//没有g,只会替换第一个123
console.log(str.replace(reg,'999')) // hello999world456你好789!

//有g,会替换所有
console.log(str.replace(reg2,'999')) // hello999world999你好999!

完结

随手笔记,如有错误,欢迎指正

更多内容细节请参见 MDN


theme: channing-cyan
highlight: atom-one-dark-reasonable


JavaScript字符串的常用方法

var str = "hello world";

// 表示str里面有多少个字符串
console.log(str.length); // 11

charAt

  • 作用:找到字符串指定索引位置的字符串

  • 语法:字符串.charAt(索引)

  • 返回值:找到的字符串,没找到返回""

var str = "hello world"

console.log(str.charAt(2)) // l
console.log(str.charAt(200)) // 没找到返回空字符串

charCodeAt

  • 作用:找到字符串指定索引位置的字符串编码

  • 语法:字符串.charCodeAt(索引)

  • 返回值:找到的编码,没找到返回NaN

var str = "hello world"

console.log(str.charCodeAt(1)) // 找到字母e对应的编码101
console.log(str.charCodeAt(100)) // NaN

indexOf

  • 作用::从头开始找指定字符的索引

  • 语法:字符串.indexOf(字符)

  • 返回值:字符的索引,没找到返回-1

var str = "hello world"

console.log(str.indexOf('h')) //0
console.log(str.indexOf('o')) //4
console.log(str.indexOf('A')) //-1

lastIndexOf

  • 作用:从末尾开始找指定字符的索引

  • 语法:字符串.lastIndexOf(字符)

  • 返回值:字符的索引,没找到返回-1

var str = "hello world"

console.log(str.lastIndexOf('l')) //9
console.log(str.lastIndexOf('o')) //7
console.log(str.lastIndexOf('A')) //-1

截取字符串中的一部分

slice

  • 作用:提取某个字符串的一部分

  • 语法:字符串.slice(start[,end])

    • 如果不写end表示截取到最末尾

    • 包括start,不包括end

  • 返回:一个新的字符串,且不会改动原字符串

var str = "abcde12345ABCDE"

// 不写end截取到最后
console.log(str.slice(5)) // 12345ABCDE

// 截取的内容包括start,不包括end
console.log(str.slice(0,5)) // abcde

// 不能这么写
console.log(str.slice(5,0))

// 可以识别负数,表示倒数第3个开始截取
console.log(str.slice(-3)) // CDE

substr

  • 作用:返回一个字符串中从指定位置开始到指定字符数的字符

  • 语法:字符串.substr(start[,length])

    • 如果不写length表示截取到最末尾
    • 从start索引开始截取length个字符
  • 返回:一个新的字符串,且不会改动原字符串

var str = "abcde12345ABCDE"

console.log(str.substr(1)) // bcde12345ABCDE
console.log(str.substr(1,4)) // bcde

substring

  • 作用:提取某个字符串的一部分

  • 语法:字符串.substring(start[,end])

    • 如果不写end表示截取到最末尾
    • 包括start,不包括end
  • 返回:一个新的字符串,且不会改动原字符串

var str = "abcde12345ABCDE"

console.log(str.substring(5)) // 12345ABCDE
console.log(str.substring(0,5)) // abcde

// 智能调换顺序
console.log(str.substring(5,0)) // abcde

// 全部截取
console.log(str.substring(-3)) // abcde12345ABCDE

repeat

  • 作用:重复字符串

  • 语法:字符串.repeat(重复的次数)

  • 返回值:一个新的重复好的字符串

var str = "hello world"

console.log(str.repeat(3)) // hello worldhello worldhello world

split

  • 作用:把字符串切分成数组

  • 语法:字符串.split("分隔符")

    • 不写分隔符,数组中只有一个元素
  • 返回值:一个新数组

var str = "hello world"

// 数组里面一个元素
console.log(str.split()) // ['hello world']

// 会以空格为分隔符
console.log(str.split(" ")) // ['hello', 'world']

// 会以空字符串为分隔符
console.log(str.split("")) // ['h', 'e', 'l', 'l', 'o', ' ', 'w', 'o', 'r', 'l', 'd']

toLowerCase/toUpperCase

  • 作用:字符串转小写/字符串转大写
  • 语法:
    • 字符串.toLowerCase()
    • 字符串.toUpperCase()
  • 返回值:一个新数字符串
var str = "abcde12345ABCDE"

console.log(str.toLowerCase()) // abcde12345abcde
console.log(str.toUpperCase()) // ABCDE12345ABCDE

String.fromCharCode(编码)

  • 作用:根据编码转成对应的字符串

  • 语法:String.fromCharCode(编码)

  • 返回值:编码对应的字符

console.log(String.fromCharCode(65)) //A
console.log(String.fromCharCode(101)) //e

concat()

  • 作用:将一个或多个字符串与原字符串连接合并,形成一个新的字符串并返回

  • 语法:str.concat(str2, [, ...strN])

  • 返回值:新的字符串

  • 强烈建议使用赋值操作符(+, +=)代替 concat 方法

var text1 = "Hello"
var text2 = "World"

console.log(text1.concat(" ",text2)) //Hello World

trim

  • 作用:删除字符串两端的空白符

  • 语法:str.trim()

  • 返回值::一个代表调用字符串两端去掉空白的新字符串

var str = "       Hello World!        "
console.log(str.trim()) // Hello World!

test

  • 作用:用来检测字符串是否符合正则的标准

  • 语法:正则.test(字符串)

  • 返回值:boolean

    • true:符合规则

    • false:不符合规则

var reg = /\d{3}/g
var reg2 = /^[a-zA-Z]+$/
var str = "hello123world456你好789!"

console.log(reg.test(str)) // true
console.log(reg2.test(str)) // false

exec

  • 作用:把字符串中符合正则的内容捕获出来

  • 语法:正则.exec(字符串)

  • 返回值:

    • 把字符串中符合正则的要求的第一项以及一些其他信息,以数组的形式返回

    • 未找到,则返回值为 null

var reg = /\d{3}/g;
var str = "hello123world456你好789!";

// 获取第一个符合条件的
var res = reg.exec(str);
console.log(res) // ["123"]

// 获取下一个符合条件
var res = reg.exec(str);
console.log(res) // ["456"]

// 获取下一个符合条件
var res = reg.exec(str);
console.log(res) // ["789"]

// 获取下一个符合条件
var res = reg.exec(str);
console.log(res) // null

search

  • 作用:查找字符串中是否有满足正则条件的内容

  • 语法:str.search(正则)

  • 返回值:正则表达式在字符串中首次匹配项的索引;否则,返回 -1

  • g不起作用

var str = "hello123world456你好789!"
var str2 = "hello"

var reg = /\d{3}/;
console.log(str.search(reg));//5
console.log(str2.search(reg));//-1

match

  • 作用:找到字符串中符合正则条件的内容返回

  • 语法:字符串.match(正则)

  • 返回值:

    • 有g:所有匹配的内容的集合

    • 没g:把字符串中符合正则的要求的第一项以及一些其他信息,以数组的形式返回

var str = "hello123world456你好789!"
var reg = /\d{3}/
var reg2 = /\d{3}/g

//有g
console.log(str.match(reg2))  // ["123", "456", "789"]

//没有g
console.log(str.match(reg)) // ["123"]

replace

  • 作用:是替换字符串中符合正则条件的字符

  • 语法:字符串.replace(正则,要替换成的新字符串)

  • 返回值:替换好的字符串

    • 有g:替换所有符合条件的

    • 没有g:替换第一个符合条件的

var str = "hello123world456你好789!"
var reg = /\d{3}/
var reg2 = /\d{3}/g

//没有g,只会替换第一个123
console.log(str.replace(reg,'999')) // hello999world456你好789!

//有g,会替换所有
console.log(str.replace(reg2,'999')) // hello999world999你好999!

完结

随手笔记,如有错误,欢迎指正

更多内容细节请参见 MDN

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容