原生JS笔记——第十天(上)

方法五:sort();

sort() 方法用于对数组的元素进行排序。

语法:
arrayObject.sort(sortby)

参数解释

参数sortby:可选。规定排序顺序。必须是函数。

1.如果不指定<方法函数>,即括号内为空,则按unicode码顺序排列(默认升序)。
2.如果指定<方法函数>,则按<方法函数>所指定的排序方法排序。

如果要比较数字:

myArray.sort(sortMethod);
注意: 该函数要比较两个值,然后返回一个用于说明这两个值的相对顺序的数字。
比较函数应该具有两个参数 a 和 b,其返回值如下:
若 a 小于 b,在排序后的数组中 a 应该出现在 b 之前,则返回一个小于 0 的值。
若 a 等于 b,则返回 0。
若 a 大于 b,则返回一个大于 0 的值。

例如:

var arr = [10,8,2,6];

var a = arr.sort(function(x,y){

​	// return x - y; //升序

​	return y - x; //降序 

});

console.log(a); //输出结果:10,8,6,2

方法六:join();

join() 方法用于把数组中的所有元素放入一个字符串。元素是通过指定的分隔符进行分隔的,默认分隔符为逗号。

语法:
arrayObject.join(separator)

参数解释

参数separator:

可选。指定要使用的分隔符。如果省略该参数,则使用逗号作为分隔符。

返回值
返回一个字符串。该字符串是通过把 arrayObject 的每个元素转换为字符串,然后
把这些字符串连接起来,在两个元素之间插入separator 字符串而生成的。
例如:

Myarr.join(“.”);

方法七:reverse();

reverse() 方法用于颠倒数组中元素的顺序。

语法:
arrayObject.reverse()

返回值:颠倒顺序后的新数组


小案例:将字符串“hello world!”进行翻转

var str = "hello world!";

var arr = str.spilt("");

arr = arr.reverse();

str = arr.join("");

console.log(str); // 输出结果:“!dlrow olleh ”

方法八:splice();

splice() 方法向(从)数组中添加(删除)项目,然后返回被删除的项目。

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

参数解释

参数1:index

必需。整数,规定添加/删除项目的位置,使用负数可从数组结尾处规定位置。

参数2:howmany

必需。要删除的项目数量。如果设置为0,则不会删除项目。

参数3:item,……,itemX

可选。向数组添加的新项目。

splice() 方法可删除从 index 处开始的零个或多个元素,并且用参数列表中声明的
一个或多个值来替换那些被删除的元素。

返回值

如果从 arrayObject 中删除了元素,则返回的是含有被删除的元素的数组。若没有删除元素,则返回空数组。


方法九:concat();

concat() 方法用于连接两个或多个数组。该方法不会改变现有的数组,而仅仅会返回被连接数组的一个副本

语法:
arrayObject.concat(arrayX,arrayX,…,arrayX)

参数解释

参数:必需。该参数可以是具体的值,也可以是数组对象。可以是任意多个。

返回值

返回一个字符串。该字符串是通过把 arrayObject 的每个元素转换为字符串,然后
把这些字符串连接起来,在两个元素之间插入separator 字符串而生成的。
例如:

Myarr.join(“.”);

方法十:slice();

concat() 方法用于连接两个或多个数组。该方法不会改变现有的数组,而仅仅会返回被连接数组的一个副本

语法:
arrayObject.concat(arrayX,arrayX,…,arrayX)

参数解释

参数1:必需。规定从何处开始选取。

参数2:必需。该参数可以是具体的值,也可以是数组对象。可以是任意多个。

返回值

返回一个字符串。该字符串是通过把 arrayObject 的每个元素转换为字符串,然后
把这些字符串连接起来,在两个元素之间插入separator 字符串而生成的。
例如:
Myarr.join(“.”);

总结:slice();与substring();的比较:

  1. 字符串和数组都可以使用slice();方法

  2. strObj.substring()两个参数均为正,arrObj.slice();两个参数都可以为负

  3. strObj.substring()

    当参数1>参数2 会先交换位置,再截取;

    arrObj.slice()

    当参数1>参数2,截取数组/字符串为空

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值