当前位置: 首页 > 工具软件 > Push.js > 使用案例 >

js中push方法小结

凌征
2023-12-01

今天笔试做一道算法题,老是通过不了,头大,直到交卷也没有通过,考完后查了一下,原来是我push的用法用错了,也是服了,重点注意这里arr.push后返回的是push的长度,我却一直用var arr=arr.push('first'),然后输出arr总是1,也是蠢爆了。。。。。。下面总结一下push方法吧

push方法是数组中的

var arr = []
var length = arr.push('first')
console.log(arr) // ['first']
console.log(length)  // 1 push方法会改变原有数组,且返回改变后数组的长度

尝试添加各种元素

var arr =  []
arr.push({})
console.log(arr)  // [Object] 
arr.push([],{},'str',1,null,undefined) // 添加多个元素用逗号隔开
console.log(arr) // Array, Object, 1, null, undefined

添加多个元素

ES6的数组扩展

var arr = [1,2,3]
var nArr = ['first', 'second', 'third'] // 想依次添加每个值到数组中
// arr.push(nArr) 如果这样添加会给arr添加多一个数组元素,arr.length = 4 
arr.push(...nArr) ES6的方法数组扩展 
console.log(arr) //  [1,2,3,'first', 'second', 'third']
// 这种扩展方法仅对Array有效

apply使用

var arr = [1,2,3]
var nArr = ['first', 'second', 'third'] // 想依次添加每个值到数组中
Array.prototype.push.apply(arr,nArr) // apply 参数传入使用数组的方式
console.log(arr) //  [1,2,3,'first', 'second', 'third']

对象能用push吗?

直接用是不行的,可以使用call方法来改用
了解V8引擎 push实现的原理

function ArrayPush () {
 var n = TO_UINT32(this.length) // 被push的对象的length
 var m = %_ArgumentsLength() // push的参数个数
 for (var i = 0; i < m; i++) {
   this[i+n] = %_Arguments(i) // 复制元素
 }
 this.length = n + m 
 return this.length 
}

其实就是一个属性复制的过程,索引值为键,添加的参数为值,还添加多一个length属性,所以push方法对对象也是可以使用的,如果对象一开始就使用了索引值为属性名,可能被后面新添加的属性替代

var obj = {}
var obj2 = {0: 'firstValue'}
Array.prototype.push.call(obj, 'first') 
Array.prototype.push.call(obj2, 'first') 
console.log(obj)  // {0: 'first', length: 1}
console.log(obj2) // {0: 'first', length: 1} 原本的'firstValue'会被替代

好的push方法到此为止再总结一下pop(),unshift(),shift()方法吧。
1、push()、pop()和unshift()、shift()

联系:这两组同为对数组的操作,并且会改变数组的本身的长度及内容。

区别:不同的是 push()、pop() 是从数组的尾部进行增减,unshift()、shift() 是从数组的头部进行增减。

 var arr = [1, 2];

2、push()和unshift()

向数组的 尾部/头部 添加若干元素,并返回 数组的 新长度;

  arr.push(3,4);         //返回 arr 的新长度 4
 
  arr ;                        // arr = [1,2,3,4];
 
  arr.unshift(0,0.5);    // 返回 arr 的新长度 6
 
  arr ;                       // arr = [0,0.5,1,2,3,4];

3、pop()和shift()

从数组的 尾部/头部 删除1个元素(删且只删除1个),并返回 被删除的元素;空数组是继续删除,不报错,但返回undefined;

  arr.pop();      //返回 4;
  
  arr ;          // arr = [0,0.5,1,2,3];
  
  arr.pop();      //返回 3;
  
     arr ;         // arr = [0,0.5,1,2];
     
  arr.shift();      // 返回 0 ;
  
  arr ;        // arr = [0.5,1,2]


PS: pop()和shift() 不接受传参,即使传了参数也没什么卵用;


  arr.pop(3) ;           // 返回 2;永远返回最后一个;
 
  arr ;        // arr = [0.5,1];
 
  arr.shift(1);    // 返回 0.5; 永远返回第一个;
 
  arr ;        // arr = [1];
 
  arr.pop() ;     // 返回 1;
 
  arr ;        // arr = [];
 
  arr.shift()     // 返回 undefined;
 
 类似资料: