首页 > 解决方案 > typescript 从数组的前端和后端获取 X 元素

问题描述

我想优化下面的代码,因为看起来步骤太多。该代码确实有效,但是我想看看是否有更好的方法。我基本上想从 shippingTracings 数组中获取第一个 X 元素和最后一个 X 元素。有没有办法优化那部分?

另外,我根据 numberOfTracings / 2 在数组的左侧和右侧推导出我想要的元素。对于奇数,我正在向下舍入,但你可以看到我正在使用 paddingRight 来使用余数(如果有) . 还有更好的方法吗?

        const numberOfTracings = environment.shipmentTracingMarkerLimit - this.shipmentTracking.shipmentStops.length;  // i.e. 7
        const paddingLeft = Math.floor(numberOfTracings / 2);
        const paddingRight = numberOfTracings - paddingLeft * 2; //i am doing this because I want to use that extra array spot to be padded.  It 
        const myFirstArr = this.shipmentTracking.shipmentTracings.slice(0, paddingLeft);
        const myFirstArr2 = this.shipmentTracking.shipmentTracings.slice(-(paddingLeft + paddingRight));
        const myFirstArr3 = myFirstArr.concat(myFirstArr2);
        myFirstArr3.forEach((shipmentTracing) => this.createRouteMarkerForTracing(shipmentTracing));

标签: javascriptarraysangulartypescript

解决方案


在评论中使用您的示例,您可以使用 ES2015扩展运算符执行以下操作:

const fruits = ["Banana", "Orange", "Lemon", "Apple", "Mango"];

const padding = 2;

const firstAndLast = [...fruits.slice(0, padding), ...fruits.slice(-padding)];

console.log(firstAndLast);

编辑:更新基于评论计算左/右切片基于padding

const fruits = ["Banana", "Orange", "Lemon", "Apple", "Mango", "Dragon Fruit", "Kiwi", "Apricot", "Lime", "Plantain"];

const getFirstAndLast = (arr, padding) => {
  const left = Math.ceil(padding / 2);
  const right = padding - left;
  return [...arr.slice(0, left), ...arr.slice(-right)];
};

// gets first 4 and last 3 given a padding of 7
const firstAndLast = getFirstAndLast(fruits, 7);

console.log(firstAndLast);


推荐阅读