splice与slice、push\pop、unshift、concat的

一、splice(index,count,object)

1>index:数组中对应的索引 2>count:对应删除索引后的个数 3>object:需要插入的表达式、字符串串、对象等

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

定义数组:

var navList = [{
           id: 'search',
            name: 'search'
        }, {
            id: 'mytv',
            name: 'menu_mytv'
        }];

例1:当count=0时

navList.splice(1, 0, {id:'zhang',name:'张'});

console.log(JSON.stringify(navList))


[{"id":"search","name":"search"},{"id":"zhang","name":"张"},{"id":"mytv","name":"menu_mytv"}]

例2:count=1

navList.splice(1, 1, {id:'li',name:'李四'});

console.log(JSON.stringify(navList))


[{"id":"search","name":"search"},{"id":"li","name":"李四"},{"id":"mytv","name":"menu_mytv"}]


navList.splice(1, 1);

console.log(JSON.stringify(navList))

[{"id":"search","name":"search"},{"id":"mytv","name":"menu_mytv"}]

例3:count>1当count=2时

navList.splice(1, 2, {id:'wang',name:'王五'});

console.log(JSON.stringify(navList))


[{"id":"search","name":"search"},{"id":"wang","name":"王五"}]

注释:请注意,splice() 方法与 slice() 方法的作用是不同的,splice() 方法会直接对数组进行修改

二、slice() 方法可从已有的数组中返回选定的元素。

名词解释:slice(index,end) 

index:从索引位置开始

end:从总数组的总长度中,选取数组长度范围内根据index截取

例1:

console.log(JSON.stringify(navList))
[{"id":"search","name":"search"},{"id":"zhang","name":"张"},{"id":"mytv","name":"menu_mytv"}]

console.log(JSON.stringify(navList.slice(1)))

 [{"id":"zhang","name":"张"},{"id":"mytv","name":"menu_mytv"}]

console.log(JSON.stringify(navList.slice(1,2)))
 [{"id":"zhang","name":"张"}]

三、定义和用法

push() 方法可向数组的末尾添加一个或多个元素,并返回新的长度。

pop() 方法可从数组的末端删除一个,并返回新的长度。

例1:

console.log(JSON.stringify(navList.push({"id":"li","name":"李四"})))

4
console.log(JSON.stringify(navList))
[{"id":"search","name":"search"},{"id":"zhang","name":"张"},{"id":"mytv","name":"menu_mytv"},{"id":"li","name":"李四"}]

例2:

console.log(JSON.stringify(navList.pop()))

3
console.log(JSON.stringify(navList))
[{"id":"search","name":"search"},{"id":"zhang","name":"张"},{"id":"mytv","name":"menu_mytv"}]

例3:

console.log(JSON.stringify(navList.push({"id":"li","name":"李四"},{"id":"wang","name":"王五"})))
console.log(JSON.stringify(navList))
[{"id":"search","name":"search"},{"id":"zhang","name":"张"},{"id":"mytv","name":"menu_mytv"},{"id":"li","name":"李四"},{"id":"wang","name":"王五"}]

四、unshift方法可向数组的开头添加,添加一个或多个元素,并返回新的长度.类似push就不举例了。

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

var arr = new Array(3)
arr[0] = "George"
arr[1] = "John"
arr[2] = "Thomas"

var arr2 = new Array(3)
arr2[0] = "James"
arr2[1] = "Adrew"
arr2[2] = "Martin"

var arr3 = new Array(2)
arr3[0] = "William"
arr3[1] = "Franklin"

document.write(arr.concat(arr2,arr3))
George,John,Thomas,James,Adrew,Martin,William,Franklin

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值