js数组,字符串常用方法汇总(面试必备)
字符串:
1、concat() – 将两个或多个字符的文本组合起来,返回一个新的字符串。
2、indexOf() – 返回字符串中一个子串第一处出现的索引。如果没有匹配项,返回 -1 。
3、charAt() – 返回指定位置的字符。
4、lastIndexOf() – 返回字符串中一个子串最后一处出现的索引,如果没有匹配项,返回 -1 。
5、match() – 检查一个字符串是否匹配一个正则表达式。
6、substring() – 返回字符串的一个子串。传入参数是起始位置和结束位置。
7、replace() – 用来查找匹配一个正则表达式的字符串,然后使用新字符串代替匹配的字符串。
8、search() – 执行一个正则表达式匹配查找。如果查找成功,返回字符串中匹配的索引值。否则返回 -1 。
9、slice() – 提取字符串的一部分,并返回一个新字符串。
10、split() – 通过将字符串划分成子串,将一个字符串做成一个字符串数组。
11、length – 返回字符串的长度,所谓字符串的长度是指其包含的字符的个数。
12、toLowerCase() – 将整个字符串转成小写字母。
13、toUpperCase() – 将整个字符串转成大写字母。
数组:
1.push(): 向数组尾部添加一个或多个元素,并返回添加新元素后的数组长度。注意,该方法会改变原数组。
1 var arr = [1,2,3];
2 console.log(arr); // [1, 2, 3]
3 var b = arr.push(4);
4 console.log(b); // 4 //表示当前数组长度
5 console.log(arr); // [1, 2, 3, 4]
pop(): 删除数组的最后一个元素,并返回该元素。注意,该方法会改变原数组。
1 var arr = [1,2,3];
2 console.log(arr); // [1,2,3]
3 arr.pop();
4 console.log( arr.pop() ); // [3] //返回删除的元素
5 console.log(arr); // [1,2]
2.unshift():在数组的第一个位置添加元素,并返回添加新元素后的数组长度。注意,该方法会改变原数组。
1 var arr = ['a', 'b', 'c'];
2 arr.unshift('x'); // 4
3 console.log(arr); // ['x', 'a', 'b', 'c']
shift():删除数组的第一个元素,并返回该元素。注意,该方法会改变原数组。
1 var arr = ['a', 'b', 'c'];
2 arr.shift() // 'a'
3 console.log(arr) // ['b', 'c']
shift()方法还可以遍历并清空一个数组。
1 var list = [1, 2, 3, 4, 5, 6];
2 var item;
3
4 while (item = list.shift()) {
5 console.log(item);
6 }
7
8 console.log(list); // []
3.valueOf():返回数组的本身。
1 var arr = [1, 2, 3];
2 arr.valueOf() // [1, 2, 3]
indexOf():返回指定元素在数组中出现的位置,如果没有出现则返回-1
。
1 var arr = ['a', 'b', 'c'];
2
3 arr.indexOf('b') // 1
4 arr.indexOf('y') // -1
indexOf方法还可以接受第二个参数,表示搜索的开始位置。
1 ['a', 'b', 'c'].indexOf('a', 1) // -1
上面代码从1号位置开始搜索字符a
,结果为-1
,表示没有搜索到。
toString():返回数组的字符串形式。
1 var arr = [1, 2, 3];
2 arr.toString() // "1,2,3"
3
4 var arr = [1, 2, 3, [4, 5, 6]];
5 arr.toString() // "1,2,3,4,5,6"
4.join():以参数作为分隔符,将所有数组成员组成一个字符串返回。如果不提供参数,默认用逗号分隔。
1 var arr = [1, 2, 3, 4];
2
3 arr.join(' ') // '1 2 3 4'
4 arr.join(' | ') // "1 | 2 | 3 | 4"
5 arr.join() // "1,2,3,4"
5.concat():用于多个数组的合并。它将新数组的成员,添加到原数组的尾部,然后返回一个新数组,原数组不变。
1 var arr = [1,2,3];
2 var b = arr.concat([4,5,6]);
3 console.log(b); //[1,2,3,4,5,6]
6.reverse():用于颠倒数组中元素的顺序,返回改变后的数组。注意,该方法将改变原数组。
1 var arr = ['a', 'b', 'c'];
2
3 arr.reverse() // ["c", "b", "a"]
4 console.log(arr) // ["c", "b", "a"]
7.slice():用于截取原数组的一部分,返回一个新数组,原数组不变。
slice(start,end)它的第一个参数为起始位置(从0开始),第二个参数为终止位置(但该位置的元素本身不包括在内)。如果省略第二个参数,则一直返回到原数组的最后一个成员。
1 var arr = ['a', 'b', 'c'];
2
3 arr.slice(0) // ["a", "b", "c"]
4 arr.slice(1) // ["b", "c"]
5 arr.slice(1, 2) // ["b"]
6 arr.slice(2, 6) // ["c"]
7 arr.slice() // ["a", "b", "c"] 无参数返回原数组
8
9 arr.slice(-2) // ["b", "c"] 参数是负数,则表示倒数计算的位置
10 arr.slice(-2, -1) // ["b"]
8.splice():删除原数组的一部分成员,并可以在被删除的位置添加入新的数组成员,返回值是被删除的元素。注意,该方法会改变原数组。
splice(start,delNum,addElement1,addElement2,...)第一个参数是删除的起始位置,第二个参数是被删除的元素个数。如果后面还有更多的参数,则表示这些就是要被插入数组的新元素。
1 var arr = ['a', 'b', 'c', 'd', 'e', 'f'];
2 arr.splice(4, 2) // ["e", "f"] 从原数组4号位置,删除了两个数组成员
3 console.log(arr) // ["a", "b", "c", "d"]
1 var arr = ['a', 'b', 'c', 'd', 'e', 'f'];
2 arr.splice(4, 2, 1, 2) // ["e", "f"] 原数组4号位置,删除了两个数组成员,又插入了两个新成员
3 console.log(arr) // ["a", "b", "c", "d", 1, 2]
1 var arr = ['a', 'b', 'c', 'd', 'e', 'f'];
2 arr.splice(-4, 2) // ["c", "d"] 起始位置如果是负数,就表示从倒数位置开始删除
1 var arr = [1, 1, 1];
2
3 arr.splice(1, 0, 2) // [] 如果只插入元素,第二个参数可以设为0
4 conlose.log(arr) // [1, 2, 1, 1]
1 var arr = [1, 2, 3, 4];
2 arr.splice(2) // [3, 4] 如果只有第一个参数,等同于将原数组在指定位置拆分成两个数组
3 console.log(arr) // [1, 2]
9.sort():对数组成员进行排序,默认是按照字典顺序排序。排序后,原数组将被改变。
1 ['d', 'c', 'b', 'a'].sort()
2 // ['a', 'b', 'c', 'd']
3
4 [4, 3, 2, 1].sort()
5 // [1, 2, 3, 4]
6
7 [11, 101].sort()
8 // [101, 11]
9
10 [10111, 1101, 111].sort()
11 // [10111, 1101, 111]
上面代码的最后两个例子,需要特殊注意。sort
方法不是按照大小排序,而是按照对应字符串的字典顺序排序。也就是说,数值会被先转成字符串,再按照字典顺序进行比较,所以101
排在11
的前面。
如果想让sort
方法按照自定义方式排序,可以传入一个函数作为参数,表示按照自定义方法进行排序。该函数本身又接受两个参数,表示进行比较的两个元素。如果返回值大于0
,表示第一个元素排在第二个元素后面;其他情况下,都是第一个元素排在第二个元素前面。
1 var arr = [10111, 1101, 111];
2 arr.sort(function (a, b) {
3 return a - b;
4 })
5 // [111, 1101, 10111]
6
7 var arr1 = [
8 { name: "张三", age: 30 },
9 { name: "李四", age: 24 },
10 { name: "王五", age: 28 }
11 ]
12
13 arr1.sort(function (o1, o2) {
14 return o1.age - o2.age;
15 })
16 // [
17 // { name: "李四", age: 24 },
18 // { name: "王五", age: 28 },
19 // { name: "张三", age: 30 }
20 // ]
10.map():对数组的所有成员依次调用一个函数,根据函数结果返回一个新数组。
1 var numbers = [1, 2, 3];
2
3 numbers.map(function (n) {
4 return n + 1;
5 });
6 // [2, 3, 4]
7
8 numbers
9 // [1, 2, 3]
上面代码中,numbers
数组的所有成员都加上1,组成一个新数组返回,原数组没有变化。
11.filter():参数是一个函数,所有数组成员依次执行该函数,返回结果为true
的成员组成一个新数组返回。该方法不会改变原数组。
1 var arr = [1, 2, 3, 4, 5]
2 arr.filter(function (elem) {
3 return (elem > 3);
4 })
5 // [4, 5]
js数组,字符串常用方法汇总(面试必备)的更多相关文章
- Java常用英语汇总(面试必备)
Java常用英语汇总(面试必备) abstract (关键字) 抽象 ['.bstr.kt] access vt.访问,存 ...
- JS数组array常用方法
JS数组array常用方法 1.检测数组 1)检测对象是否为数组,使用instanceof 操作符 if(value instanceof Array) { //对数组执行某些操作 } 2)获取对象的 ...
- js数组,字符串,json互相转换函数有哪些
js数组,字符串,json互相转换函数有哪些 一.总结 一句话总结: JSON.stringify(arr) JSON.parse(jsonString) str.split('') array.jo ...
- js数据类型以及数组字符串常用方法
JS判断数据类型 例子: var a = "iamstring."; var b = 222; var c= [1,2,3]; var d = new Date(); var e ...
- js数组去重常用方法
js数组去重是面试中经常会碰到的问题,无论是前端还是node.js数组常见的有两种形式,一种是数组各元素均为基本数据类型,常见的为数组字符串格式,形如['a','b','c'];一种是数组各元素不定, ...
- js 数组的常用方法归纳
数组的常用方法归纳 slice(start,end) 传参:start代表从哪里开始截取,end代表截取结束的地方 var a = [1,2,3]a.slice(1);//[2,3] pop() 可以 ...
- js数组的常用方法(10种)
数组的常用方法 数组在JavaScript中经常使用,如何对数组进行增删改非常重要,下面为数组的常用方法: 在数组末尾插入元素 arr.push(value),在数组的末尾添加一个或多个元素,并返回数 ...
- js数组&&字符串&&定时器2
一.系统时间对象Date 方法 描述 Date() 返回当日的日期和时间. getDate() 从 Date 对象返回一个月中的某一天 (1 ~ 31). getDay() 从 Date 对象返回一周 ...
- JS 数组Array常用方法
参考网站: http://www.jb51.net/article/60502.htm,作者:junjie 今天在使用js切割字符串"浙江,江苏 , 天津,"...这样字符串的时候 ...
- js 数组去重方法汇总
<!DOCTYPE html> <html lang="zh"> <head> <meta charset="UTF-8&quo ...
随机推荐
- 2017《JAVA技术》预备作业
1.阅读邹欣老师的博客,谈谈你期望的师生关系是什么样的? ==我期望的师生关系是长辈和晚辈,前辈和后生,朋友与朋友之间的关系,作为晚辈,要尊敬长辈,不能对长辈进行言语攻击和起冲突:作为后生,要谨遵教诲 ...
- 《JAVASCRIPT高级程序设计》创建对象的七种模式
细看javascript创建对象模式的诞生,具体的脉络为:不使用任何模式——工厂模式——构造函数模式——原型模式——组合使用构造函数模式——动态原型模式——寄生构造函数模式——稳妥构造函数模式.每一种 ...
- 免越狱tweak应用逆向开发
对于已越狱的设备,系统默认安装了mobilesubstrate动态库,提供一个系统级的入侵管道,所有的tweak都可以依赖它来进行开发.而对于没有越狱的手机,我们需要向目标app注入libsubstr ...
- 计算机程序的思维逻辑 (64) - 常见文件类型处理: 属性文件/CSV/EXCEL/HTML/压缩文件
对于处理文件,我们介绍了流的方式,57节介绍了字节流,58节介绍了字符流,同时,也介绍了比较底层的操作文件的方式,60节介绍了随机读写文件,61节介绍了内存映射文件,我们也介绍了对象的序列化/反序列化 ...
- 冬天 苹果笔记 macbook pro 消除静电的方法
冬天mac除静电的方法 1.mac虽然声称不需要关机,但和apple技术人员沟通后,还是需要1周进行一次关机操作 2.通过苹果黑科技重置面板上的静电,如下: apple官方的地址: https://s ...
- 毕向东tcp学习笔记1
项目功能: 实现一次发送和接收,服务器接收客户端发送的内容并打印出来 用最通俗的语言讲解下,上图中大椭圆是服务器,A.C是客户端,当客户端和服务器通过socket建立连接后 1.两者之间形成一个通道, ...
- matlab for循环的三种类型
学习了一半了,发现一个好网站,就是我想写这篇博客用的,网络真是个好东西!纪念下国庆啦 网址:http://www.yiibai.com/matlab/matlab_for_loop.html ---- ...
- https post
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.N ...
- JUnit与JMock学习
JUnit与JMock学习 测试驱动编程和持续集成部署应该说是现在软件开发者的必备武器,不过跟其他很多好东西一样,在我们公司的推广总要慢上一拍,毕竟老板看的是你能够把功能实现好让客户满意,所以能不折腾 ...
- IOS缓存管理之PINCache使用
前言: 今年重点在于公司iOS架构的梳理工作,上周整理了http请求接口管理与解耦,接下来准备整理一下项目中的缓存处理,目前项目中使用的是PINCache,去年加入这个开源框架时并没有对这个框架进行了 ...