JS中字符串和数组常用方法

4 篇文章 0 订阅
4 篇文章 0 订阅

字符串常用方法:

1.length字符串长度

var str = "hello"
str.length; // 5
//用length属性取得字符串的长度

2. charAt()获取某个字符

str.charAt(n)
//返回字符串的第 n 个字符,如果不在 0~str.length-1之间,则返回一个空字符串。

3.indexOf()检测字符在字符串的位置

indexOf(substr[,start])
//返回 substr 在字符串 str 中首次出现的位置,从 start 位置开始查找,如果不存在,则返回 -1。 

4.截取字符串

4.1 substring()提取某些指定字符
str.substring(start,stop)
// start 提取的子串的第一个字符在 str中的位置。
//stop 提取的子串的最后一个字符在 str中的位置多 1

//例子:
var str="Hello world!"
document.write(str.substring(3)) //输出lo world!

4.2 substr() 截取的字符串
substr(string,start)
//string 指定的要截取的字符串
//start	规定在字符串的何处开始:
//返回新的字符串
5. replace()字符串替换
str.replace(old, new)
//old 将被替换的子字符串。
//new 新字符串,用于替换old子字符串。
6.spilt() 把一个字符串分割成字符串数组

数组转字符串方法

slice() 从已有的数组中返回选定的元素
str.slice(start[,end])
//返回从 start 到 end (不包括)之间的字符,可传负值
push(): 向数组尾部添加一个或多个元素
var arr = [1,2,3];
console.log(arr);        //  [1, 2, 3]
var b = arr.push(4);  
console.log(b);          //  4   //表示当前数组长度
console.log(arr);        // [1, 2, 3, 4]  
indexOf():检测元素在数组中出现的位置
 var arr = ['a', 'b', 'c'];

 arr.indexOf('b') // 1
 arr.indexOf('y') // -1
//返回指定元素在数组中出现的位置,如果没有出现则返回-1。

//indexOf方法还可以接受第二个参数,表示搜索的开始位置。

['a', 'b', 'c'].indexOf('a', 1)     // -1
//从1号位置开始搜索字符a,结果为-1,表示没有搜索到
toString():数组转字符串
var arr = [1, 2, 3];
arr.toString()     // "1,2,3"

var arr = [1, 2, 3, [4, 5, 6]];
arr.toString()     // "1,2,3,4,5,6"
join() 将数组分割为字符串
var arr = [1, 2, 3, 4];

arr.join(' ')     // '1 2 3 4'
arr.join(' | ')     // "1 | 2 | 3 | 4"
arr.join()     // "1,2,3,4"
reverse() 翻转数组排序
var arr = ['a', 'b', 'c'];

arr.reverse() // ["c", "b", "a"]
console.log(arr) // ["c", "b", "a"]
slice():用于截取原数组的一部分,返回一个新数组,原数组不变。

slice(start,end)它的第一个参数为起始位置(从0开始),第二个参数为终止位置(但该位置的元素本身不包括在内)。如果省略第二个参数,则一直返回到原数组的最后一个成员。

var arr = ['a', 'b', 'c'];
 
arr.slice(0)         // ["a", "b", "c"]
arr.slice(1)         // ["b", "c"]
arr.slice(1, 2)      // ["b"]
arr.slice(2, 6)      // ["c"]
arr.slice()          // ["a", "b", "c"]    无参数返回原数组
arr.slice(-2)        // ["b", "c"]    参数是负数,则表示倒数计算的位置
arr.slice(-2, -1)    // ["b"] 

splice():删除原数组的一部分成员,并可以在被删除的位置添加入新的数组成员,返回值是被删除的元素。注意,该方法会改变原数组。

splice(start,delNum,addElement1,addElement2,…)第一个参数是删除的起始位置,第二个参数是被删除的元素个数。如果后面还有更多的参数,则表示这些就是要被插入数组的新元素。

var arr = ['a', 'b', 'c', 'd', 'e', 'f'];
arr.splice(4, 2)     // ["e", "f"]  从原数组4号位置,删除了两个数组成员
console.log(arr)     // ["a", "b", "c", "d"]

var arr = ['a', 'b', 'c', 'd', 'e', 'f'];
arr.splice(4, 2, 1, 2)     // ["e", "f"]  原数组4号位置,删除了两个数组成员,又插入了两个新成员
console.log(arr)         // ["a", "b", "c", "d", 1, 2]

var arr = ['a', 'b', 'c', 'd', 'e', 'f'];
arr.splice(-4, 2)     // ["c", "d"]    起始位置如果是负数,就表示从倒数位置开始删除
var arr = [1, 1, 1];

arr.splice(1, 0, 2)     // []    如果只插入元素,第二个参数可以设为0
conlose.log(arr)     // [1, 2, 1, 1]

var arr = [1, 2, 3, 4];
arr.splice(2)     // [3, 4] 如果只有第一个参数,等同于将原数组在指定位置拆分成两个数组
console.log(arr)     // [1, 2]
sort():对数组进行排序

默认是按照字典顺序排序。排序后,原数组将被改变。

['d', 'c', 'b', 'a'].sort()
// ['a', 'b', 'c', 'd']
 
[4, 3, 2, 1].sort()
 // [1, 2, 3, 4]

[11, 101].sort()
// [101, 11]

[10111, 1101, 111].sort()
// [10111, 1101, 111]

上面代码的最后两个例子,需要特殊注意。

sort方法不是按照大小排序,而是按照对应字符串的字典顺序排序。也就是说,数值会被先转成字符串,再按照字典顺序进行比较,所以101排在11的前面。

如果想让sort方法按照自定义方式排序,可以传入一个函数作为参数,表示按照自定义方法进行排序。

该函数本身又接受两个参数,表示进行比较的两个元素。如果返回值大于0,表示第一个元素排在第二个元素后面;其他情况下,都是第一个元素排在第二个元素前面。

var arr = [10111, 1101, 111];
arr.sort(function (a, b) {
	return a - b;
})

// [111, 1101, 10111]

var arr1 = [
 	{ name: "张三", age: 30 },
	{ name: "李四", age: 24 },
	{ name: "王五", age: 28 }
]

arr1.sort(function (o1, o2) {
   return o1.age - o2.age;
}) 
 // [
//   { name: "李四", age: 24 },
//   { name: "王五", age: 28 },
//   { name: "张三", age: 30 }
// ]
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值