专栏首页佛曰不可说丶总结js数组和字符串常用的api

总结js数组和字符串常用的api

一、数组API

  1. 连接:arr.join("连接符")

用连接符把数组里面的元素连接成字符串。

arr.join("")能无缝连接。

2.拼接:arr.concat("a","b",arr1)

强调:(1)不会修改原数组,返回新数组。

(2)concat方法中的数组会被打散为单个元素再拼接。

3.截取:arr.slice(start[,end])

强调:(1)不会修改原数组,返回新的子数组。

(2)含头不含尾。

(3)省略第二个参数表示从start位置开始一直截取到末尾。

(4)支持负数,表示倒数第几个。

4. 删除、插入、替换:arr.splice(start,n[,value1,value2...])

强调:(1)直接修改原数组。

(2)返回所有被删除元素组成的子数组。

(3)如果是插入,删除了0个数,那么从start位置开始以及之后的元素会被顺移。

5. 翻转数组:arr.reverse()

强调:(1)直接修改原数组。

6.数组排序:arr.sort()

强调:(1)直接修改原数组。

(2)默认按照数组元素第一位的ASCII码从小到大排列。

(3)可以设置下列的比较器函数来控制升序,降序或者打乱。

(4)arr.sort(function(a,b){return a-b;}); 升序(只限数组中是数字或者数字字符串)。

(5)arr.sort(function(a,b){return b-a;}); 降序(只限数组中是数字或者数字字符串)。

(6)arr.sort(function(){

return Math.random()>.5 ? 1 : -1;

});随机打乱数组(数组中可以是任何数据类型)

  1. 查找:arr.indexOf(value[,from])或arr.lastIndexOf(value[,from])

强调:(1)返回value在数组中的位置,没有找到返回-1。

8. 是否有符合的:arr.some(function(value,index,arr){

return value > 7;

})

强调:(1)判断数组中有没有符合条件的元素,只要遇到符合条件的就退出循环。

(2)返回boolean值。

9.是否都符合:arr.every(function(value,index,arr){return value > 7;})

强调:(1)判断数组中的元素是否都符合条件。

(2)返回boolean值。

10. 过滤数组:arr.filter(function(value,index,arr){return value > 7;})

强调:(1)过滤数组,返回符合条件的元素组成的新数组。

11. 循环数组,无返回值:arr.forEach(function(value,index,arr){})

12. 循环数组,有返回值:arr.map(function(value,index,arr){})

13.汇总:arr.reduce(function(prev,value,index,arr){

return prev + value;

})

返回数组里面所有元素相加的和。prev是之前那些元素的和。

14. 数组转字符串:String(arr)或arr.toString()

将数组中的元素用逗号连接成字符串,类似于arr.join(",")。

15. 开头入栈:arr.unshift(value)

在数组的最开头插入元素。

强调:(1)修改原数组。

(2)返回新数组的length。

16. 开头出栈:arr.shift()

弹出数组最开头的元素。

强调:(1)修改原数组。

(2)返回被弹出的元素。

17. 结尾入栈:arr.push(value1[,value2,arr1])

在数组末尾追加元素。

强调:(1)修改原数组。

(2)返回新数组的length。

(3)追加进去的数组不会被打散。

18. 结尾出栈:arr.pop()

弹出数组最末尾的元素。

强调:(1)修改原数组。

(2)返回被弹出的元素。

二、字符串API

1. 截取:str.slice(from[,end])或str.substring(start[,end])或str.substr(start[,length])

强调:(1)slice和substring用法类似,只是slice支持负数,而substring的负数会被转换成0,然后截取0和start之间字符。

(2)substr的start支持负数。

2. 分割:str.split("分割符")

把字符串以分割符为界点分割成数组。

3. 查找:str.indexOf(value[,from])或str.lastIndexOf(value[,from])

强调:(1)indexOf()只查找第一个,找不到返回-1。

4. 替换:str.replace("被替换字符","替换字符")

强调:(1)只会替换第一个,如果要替换所有符合条件的字符可以使用正则g。

5. 拼接:str.concat(value)

把value拼接到str上,效果类似于str+value

6. 获取指定位置字符:str.charAt(index)或str[index]

7. 去掉字符串前后空格:str.trim()

8. 字符串转ASCII:str.charCodeAt(index)

9. ASCII转字符串:String.fromCharCode(Unicode)

10. 转大写字母:str.toUpperCase()

11. 转小写字母:str.toLowerCase()

三、4种字符串“查找”方法的对比

1. str.indexOf(value[,from])

强调:(1)只能查找第一个匹配的位置,没找到返回-1,可用循环改变from查找所有。

2. str.search(reg)

强调:(1)仅判断有没有。

(2)只返回第一个匹配的位置,没找到返回-1。

(3)支持正则(不支持g,支持i)。

3. str.match(reg)

强调:(1)返回所有正则匹配的字符串组成的数组,没找到返回null。

(2)支持正则,正则表达式必须带g,才能返回所有匹配的字符串。

4. reg.exec(str)

既能找到关键词的位置,又能获得内容。

强调:(1)支持正则,找不到返回null。

(2)若要查找所有正则必须加g,不加g只能查找第一个,而且要放进循环里面。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • flex深度剖析-解决移动端适配问题!

    上回说到,移动端适配,推荐了,使用px为主,vw,百分比为辅助,再搭配flex的布局方式,于是有人就开始问我了,这个flex搭配布局应该怎么用,梳理一遍,巩固一...

    用户7413032
  • ts的九大数据类型,记录一下

    用户7413032
  • 彻底搞定import export

    ES6中导入模块,使用 import 模块名称 from '模块标识符' import '表示路径'

    用户7413032
  • 剑指offer__3__数组中重复的数字

    描述:在一个长度为n的数组里所有的数字都在0~n-1的范围内,数组中某些数字是重复的,但是不知道有几个数字重复了,也不知道每个数字重复了几次。请找出数组中任意一...

    用户6055494
  • 《算法图解》NOTE 2 数组、链表及选择排序1.数组2.链表3.选择排序法

    billyang916
  • JavaScript下的算法基础

    给定一个整数数组nums和一个目标值target,请你在该数组中找出和为目标值的那两个整数,并返回他们的数组下标。

    Dreamy.TZK
  • 程序员那些必须掌握的排序算法(上)

    现在的IT行业并不像以前那么好混了,从业人员过多,导致初级程序员过剩,这也间接导致了公司的招聘门槛越来越高,要求程序员掌握的知识也越来越多。 算法也是一个争论...

    wangweijun
  • javascript数组去重的N种方法

    这段代码使用了循环嵌套,首先循环遍历数组中每一项,然后用每一项和当前项后面的数组元素比对,相同的话,将其从数组中删除,依次循环完成,达到去重目的。

    挥刀北上
  • JAVA中的数组

    1 动态初始化 方法:数据类型[] 数组名 = new 数据类型[数组长度] 例如:

    roobtyan
  • 【Leetcode】141.环形链表

    为了表示给定链表中的环,我们使用整数 pos 来表示链表尾连接到链表中的位置(索引从 0 开始)。如果 pos 是 -1,则在该链表中没有环。

    Leetcode名企之路

扫码关注云+社区

领取腾讯云代金券