TS实现原生数组方法之pop()、push()、shift()、unshift()

本文介绍了JavaScript中的四个数组方法:pop、push、shift和unshift,通过实例展示了它们如何改变原数组,以及在实际编程中的应用。通过对数组元素的增删操作,理解这些方法对于数组操作的重要性。
摘要由CSDN通过智能技术生成
/**
 * pop(): 从数组中删除最后一个元素,并返回该元素的值,改变原数组。
 * push(): 将一个或多个元素添加到数组的末尾,并返回该数组的新长度,改变原数组。
 * shift(): 从数组中删除第一个元素,并返回该元素的值,改变原数组。
 * unshift(): 将一个或多个元素添加到数组的开头,并返回该数组的新长度,,改变原数组。
 */
 
Array.prototype.pop = function () {
  const array = Object(this);
  const _len = array.length;
  const result = array[_len - 1];
  delete array[_len - 1];
  array.length = _len - 1;
  return result;
}

Array.prototype.push = function (...items: any[]): number {
  const array = Object(this);
  const _len = array.length;
  for (let i = 0; i < items.length; i++) {
    array[_len + i] = items[i];
  }
  return array.length;
}

Array.prototype.shift = function () {
  const array = Object(this);
  const _len = array.length;
  const result = array[0];
  for (let i = 0; i < _len - 1; i++) {
    array[i] = array[i + 1];
  }
  array.length = _len - 1;
  return result;
}

Array.prototype.unshift = function (...items: any[]): number {
  const array = Object(this);
  const _len = array.length;
  for (let i = _len + items.length - 1; i >= items.length; i--) {
    array[i] = array[i - items.length];
  }
  for (let i = 0; i < items.length; i++) {
    array[i] = items[i];
  }
  return array.length;
}

//test data
const popData = ['angel', 'clown', 'mandarin', 'surgeon'];

console.log('调用 pop 之前: ' + popData);
// "调用 pop 之前: angel,clown,mandarin,surgeon"

const poped = popData.pop();

console.log('调用 pop 之后: ' + popData);
// "调用 pop 之后: clown,mandarin,surgeon"

console.log('被删除的元素: ' + poped);
// "被删除的元素: surgeon"

const pushData = ['angel', 'clown', 'mandarin', 'surgeon'];

console.log('调用 pushed 之前: ' + pushData);
// "调用 pushed 之前: angel,clown,mandarin,surgeon"

/** @ts-ignore */
const pushed = pushData.push('test', ['yaling', 'baisong']);

console.log('调用 pushed 之后: ' + pushed);
// "调用 pushed 之后: 6"

console.log('调用 pushed 之后的数组为: ' + pushData);
// "调用 pushed 之后的数组为: angel,clown,mandarin,surgeon,test,yaling,baisong"


const shiftData = ['angel', 'clown', 'mandarin', 'surgeon'];

console.log('调用 shift 之前: ' + shiftData);
// "调用 shift 之前: angel,clown,mandarin,surgeon"

const shifted = shiftData.shift();

console.log('调用 shift 之后: ' + shiftData);
// "调用 shift 之后: clown,mandarin,surgeon"

console.log('被删除的元素: ' + shifted);
// "被删除的元素: angel"

const unshiftData = [4, 5, 6];
unshiftData.unshift(1, 2, 3);
/** @ts-ignore */
const unshifted = unshiftData.unshift([-7, -6], [-5]);
console.log('调用 unshift 之后: ' + unshifted);
// "调用 unshift 之后: 8"

console.log('调用 unshift 之后的数组为: ' + unshiftData);
// "调用 unshift 之后的数组为: -7,-6,-5,1,2,3,4,5,6"
  • 2
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值