当前位置:首页 > 技术分享 > 正文内容

substring、slice、splice、split、join、match、replace方法总结

admin6个月前 (12-30)技术分享726

js 常用的一些操作字符串和数组的方法经常容易混淆,忙里偷闲整理了一下,请看


1. substring() 方法

用法:substring() 方法用于提取字符串中介于两个指定下标之间的字符。

语法:string.substring(start,stop)


示例:
let str = "0123456789"
 
str.substring(0)   // 0123456789 输入0会原字符串输出
str.substring(3)   // 3456789    从第三位开始截取,如果第二个参数忽略则截取到字符串末尾
str.substring(3,7)   // 3456  前包括后不包括


提示:substring 不支持负数,如果是负数会输出原字符串

2. substr() 方法

用法: substr() 方法可在字符串中抽取从 开始 下标开始的指定数目的字符。

提示: substr() 的参数指定的是子串的开始位置和长度,因此它可以替代 substring() 和 slice() 来使用

注意: ECMAscript 没有对该方法进行标准化,因此反对使用它

语法:string.substr(start, length)


示例:
let str = "0123456789"
 
str.substr(0)   // 0123456789   输入0会原字符串输出
 
str.substr(3))   // 3456789
 
str.substr(-3)   // 789
 
str.substr(3,5)  // 34567  
 
str.substr(3,6)  // 345678 从第三位截取,截取6位字符  (第二位参数不支持负数)


3. slice() 方法

用法:slice() 方法可从已有的数组中返回选定的元素。

           slice() 方法可提取字符串的某个部分,并以新的字符串返回被提取的部分。

语法:array.slice(start,end)

示例:
let arr = ["one", "two", "three","four", "five"]
 
arr.slice(1,3)  // ["two","three"]
 
arr.slice(0, -1) // ["one", "two", "three","four"]  ( 去掉最后一位 )
 
let str = "0123456789"
 
str.slice(0)   // 原字符串输出
 
str.slice(3)   // 345678  从第三位开始截取,如果第二个参数忽略则截取到字符串末尾
 
str.slice(3,6)   // 345
 
str.slice(-3)   // 789
 
str.slice(0,-3)   // 0123456   ( 截取后三位 )
 
提示:数组和字符串处理结果一致

4. splice() 方法

用法:splice() 方法用于添加或删除数组中的元素。

注意:这种方法会改变原始数组。

语法:array.splice(index,howmany,item1,...itemX)


示例:
let arr = ["one", "two", "three","four", "five"]
 
arr.splice(2,1)   // ["three"]  (从第二个删除,删除1个元素)
 
console.log(arr)   // ["one","two","four","five"] (原数组返回值)
 
arr.splice(2,1,"hello","world")  // ["three"]
 
console.log(arr) // ["one", "two", "hello", "world", "four", "five"]

 

注意:splice()方法只能操作数组,不能操作字符串,否则会报错

5. split() 方法

用法:split() 方法用于把一个字符串分割成字符串数组。

语法:string.split(separator,limit)


示例:
let str = "hello"
 
str.split("")  // ["h", "e", "l", "l", "o"]
 
str.split(" ") // ["hello"]
 
let str = "wang xin yan"
 
str.split(" ")  // ["wang", "xin", "yan"]
 
let str = "ni hao wagn xin yan"
 
str.split("", 3) // ["ni", "hao", "wang"]
 
使用一个字符作为分隔符:
let str = "how are you doing today"
 
str.split("o") // ["h","w are y","u d","ing t","day"]


6. join() 方法

用法:join() 方法用于把数组中的所有元素转换一个字符串。元素是通过指定的分隔符进行分隔的

语法:array.join()


示例:

let arr = ["one","two","three"]
 
arr.join("")  // "onetwothree"
 
arr.join("-")  // "one-two-three"
 
arr.join(",") // "one,two,three"
 
arr.join() // "one,two,three"  默认以逗号分隔


7. match() 方法

用法:match() 方法可在字符串内检索指定的值,或找到一个或多个正则表达式的匹配。

语法:string.match(regexp)


示例:

let str = "the rain is mainly in the plain"
 
str.match(/ain/g)  // ["ain","ain","ain"]
 
str.match(/ain/g).length  // 3   有3处匹配字符串


8. replace() 方法

用法:replace() 方法用于在字符串中用一些字符替换另一些字符,或替换一个与正则表达式匹配的子串。

语法:string.replace(searchvalue,newvalue)


示例:
let str = "nihao wangxy"
 
str.replace(/nihao/gi,"hello")  // hello wangxy

 

提示:g 全局匹配  i是否忽略大小写

 slice(),substr(),substring()基于子字符串创建新字符串的方法  |  slice()和splice()操作数组

扫描二维码推送至手机访问。

版权声明:本文由小刚刚技术博客发布,如需转载请注明出处。

本文链接:https://blog.bitefu.net/post/637.html

标签: js
分享给朋友:

相关文章

php高效检测远程图片是否存在

php高效检测远程图片是否存在function img_exits($url){     $ch = curl_init();    &...

安装Windows 10X 教你如何安装Win10X正式版 及下载地址

安装Windows 10X 教你如何安装Win10X正式版 及下载地址

安装Windows 10X 教你如何安装Win10X正式版:Windows 10X是Windows 10操作系统的新版本,主要针对双屏电脑。由于即将运行Windows 10X的双屏电脑(例如即将面世的Surface Neo)的开发遇到挫折,...

PHP和Redis实现在高并发下的抢购及秒杀功能

抢购、秒杀是平常很常见的场景,面试的时候面试官也经常会问到,比如问你淘宝中的抢购秒杀是怎么实现的等等。抢购、秒杀实现很简单,但是有些问题需要解决,主要针对两个问题:一、高并发对数据库产生的压力二、竞争状态下如何解决库存的正确减少("...

遭遇国外ip抓取或攻击怎么办一招解决禁止海外IP访问

遭遇国外ip抓取或攻击怎么办一招解决禁止海外IP访问

究发现很多网站被攻击都是来自海外的肉鸡,所以禁掉海外IP访问网站也是不错的防护手段,而且国内网站几乎很少有国外用户访问,称之为大局域网也不为过。今天主机吧来教大家如何利用域名解析禁止掉海外IP访问网站。绝大多数域名解析服务商都是提供电信联通...

在CentOS 5.x 6.x里使用yum源 换阿里云国内源换vault.centos.org源

阿里云CentOS 5 的系统,无法用yum来安装应用软件。  原因:CentOS 5 在2017-03-31日已经结束支持,不再提供维护更新,所以包括阿里云镜像站的文件可能都是过时或已经有部分文件缺失。 &n...

用apicloud 免费,简单封装一个wap手机网站成android app

用apicloud 免费,简单封装一个wap手机网站成android app

APICloud是国内较早布局低代码开发的平台之一,其发布的低代码效率工具Plus Mode,为IT项目中每个角色提供专业工具,将需求分析、产品原型、UI设计、前端开发、后端开发紧密衔接,并基于行业大数据对前置环节进行复用,最终缩减大量重复...

发表评论

访客

看不清,换一张

◎欢迎参与讨论,请在这里发表您的看法和观点。