join、split、slice、splice、substring、substr、unshift方法的使用

join、split、slice、splice、substring、substr、unshift方法的使用

(1)join() 方法将数组作为字符串返回。

​ 元素将由指定的分隔符分隔。默认分隔符是逗号 (,)。

注释: join() 方法不会改变原始数组

语法
array.join(separator)
参数值
参数描述
separator可选。要使用的分隔符。如果省略,元素用逗号分隔。
技术细节
返回值:字符串值,表示数组值,由指定的分隔符分隔。
示例:
const fruits = ["Banana", "Orange", "Apple", "Mango"];
console.log(fruits.join('/'))//  输出:Banana/Orange/Apple/Mango

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

注释: split() 方法不会改变原始字符串

语法
stringObject.split(separator,howmany)
参数描述
separator必需。字符串或正则表达式,从该参数指定的地方分割 stringObject。
howmany可选。该参数可指定返回的数组的最大长度。如果设置了该参数,返回的子串不会多于这个参数指定的数组。如果没有设置该参数,整个字符串都会被分割,不考虑它的长度。
返回值

一个字符串数组。该数组是通过在 separator 指定的边界处将字符串 stringObject 分割成子串创建的。返回的数组中的字串不包括 separator 自身。

但是,如果 separator 是包含子表达式的正则表达式,那么返回的数组中包括与这些子表达式匹配的字串(但不包括与整个正则表达式匹配的文本)。

注意:

如果把空字符串 (“”) 用作 separator,那么 stringObject 中的每个字符之间都会被分割。

String.split() 执行的操作与 Array.join 执行的操作是相反的。

示例:
var str="How are you doing today"
console.log(str.split(" ",3));//  输出: ['How', 'are', 'you']
console.log(str);//How are you doing today

(3)slice() 方法以新的数组对象,返回数组中被选中的元素。

slice() 方法选择从给定的 start 参数开始的元素,并在给定的 end 参数处结束,但不包括。

注释: slice() 方法不会改变原始数组

语法
array.slice(start, end)
参数值
参数描述
start可选。整数,指定从哪里开始选择(第一个元素的索引为 0)。使用负数从数组的末尾进行选择。如果省略,则类似于 “0”。
end可选。整数,指定结束选择的位置。如果省略,将选择从开始位置到数组末尾的所有元素。使用负数从数组末尾进行选择。
技术细节
返回值:新的数组,包含选定的元素。
示例:
var str="How are you doing today"
console.log(str.slice(2,9));//  输出: w are y

(4)splice() 方法用于将项目添加到数组

定义和用法

splice() 方法向/从数组添加/删除项目,并返回删除的项目。

注释: splice() 方法会改变原始数组

语法
array.splice(index, howmany, item1, ....., itemX)
参数描述
index必需。整数,指定在什么位置添加/删除项目,使用负值指定从数组末尾开始的位置。
howmany可选。要删除的项目数。如果设置为 0,则不会删除任何项目。
item1, …, itemX可选。要添加到数组中的新项目。
返回值
返回值:新数组,包含删除的项目(如果有)。
示例:
//在位置 2,添加新项目,并删除 1 个项目
var fruits = ["Banana", "Orange", "Apple", "Mango"];
fruits.splice(2, 1, "Lemon", "Kiwi");//  输出: ['Apple']
console.log(fruits);//输出:['Banana', 'Orange', 'Lemon', 'Kiwi', 'Mango']
//在位置 2,删除 2 个项目:
var fruits = ["Banana", "Orange", "Apple", "Mango"];
fruits.splice(2, 2);//输出: ['Lemon', 'Kiwi']

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

注释: substring() 方法不会改变原始字符串

语法
stringObject.substring(start,stop)
参数描述
start必需。一个非负的整数,规定要提取的子串的第一个字符在 stringObject 中的位置。
stop可选。一个非负的整数,比要提取的子串的最后一个字符在 stringObject 中的位置多 1。如果省略该参数,那么返回的子串会一直到字符串的结尾。
返回值

一个新的字符串,该字符串值包含 stringObject 的一个子字符串,其内容是从 start 处到 stop-1 处的所有字符,其长度为 stopstart

说明

substring() 方法返回的子串包括 start 处的字符,但不包括 stop 处的字符。

如果参数 startstop 相等,那么该方法返回的就是一个空串(即长度为 0 的字符串)。如果 startstop 大,那么该方法在提取子串之前会先交换这两个参数。

**重要事项:**与 slice()substr() 方法不同的是,substring() 不接受负的参数。

示例:
var str="How are you doing today"
console.log(str.substring(5));//  输出: re you doing today
console.log(str);//How are you doing today

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

注释: substr() 方法不会改变原始字符串

语法
stringObject.substr(start,length)
参数描述
start必需。要抽取的子串的起始下标。必须是数值。如果是负数,那么该参数声明从字符串的尾部开始算起的位置。也就是说,-1 指字符串中最后一个字符,-2 指倒数第二个字符,以此类推。
length可选。子串中的字符数。必须是数值。如果省略了该参数,那么返回从 stringObject 的开始位置到结尾的字串。
返回值

一个新的字符串,包含从 stringObjectstart(包括 start 所指的字符) 处开始的 length 个字符。如果没有指定 length,那么返回的字符串包含从 startstringObject 的结尾的字符。

提示和注释

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

重要事项: ECMAscript 没有对该方法进行标准化,因此反对使用它。

重要事项: 在 IE 4 中,参数 start 的值无效。在这个 BUG 中,start 规定的是第 0 个字符的位置。在之后的版本中,此 BUG 已被修正。

示例:
var str="How are you doing today"
console.log(str.substr(4,9));//  输出: are you d
console.log(str);//How are you doing today

(7)unshift() 方法将新项目添加到数组的开头

定义和用法

unshift() 方法将新项添加到数组的开头,并返回新的长度。

注释: unshift() 方法 会改变数组的长度

提示: 如需在数组末尾添加新项,请使用 push() 方法。

语法
array.unshift(item1, item2, ..., itemX)stringObject.substr(start,length)
参数描述
item1, item2, …, itemX必需。要添加到数组开头的项。
返回值
返回值:数值,表示数组的新长度。
示例:
var fruits = ["Banana", "Orange", "Apple", "Mango"];
fruits.unshift("Lemon","Pineapple");//  输出: 6
console.log(fruits);// ['Lemon', 'Pineapple', 'Banana', 'Orange', 'Apple', 'Mango']

总结:

var fruits = ["Banana", "Orange", "Apple", "Mango"];
console.log(fruits.join('/'))// Banana/Orange/Apple/Mango
var str="How are you doing today"
console.log(str.split(" ",3));// ['How', 'are', 'you']
console.log(str);//How are you doing today
console.log(str.slice(2,9));//w are y
console.log(str.substring(5));//re you doing today
console.log(str);//How are you doing today
console.log(str.substr(4,9));//are you d
console.log(str);//How are you doing today
console.log(fruits.unshift("Lemon","Pineapple"))//6
console.log(fruits);// ['Lemon', 'Pineapple', 'Banana', 'Orange', 'Apple', 'Mango']
console.log(fruits.splice(2, 1, "Lemon", "Kiwi"));//['Banana']
console.log(fruits);//['Lemon', 'Pineapple', 'Lemon', 'Kiwi', 'Orange', 'Apple', 'Mango']
console.log(fruits.splice(2, 2))//['Lemon', 'Kiwi']

在这里插入图片描述

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值