从数组中选取特定元素

Pick specific elements from array

本文关键字:元素 选取 数组      更新时间:2023-09-26

我有一个包含 17 张图像的数组。我想从阵列中挑选每个图像并将其放在舞台上,但应该有一种特定的方式来做到这一点。在我选择了第一张图片后,我需要第 1 张图片,所以这应该看起来像这样:

var myarray = [0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16]; // these are the indexes for the 17 images

挑选元素的顺序如下所示:[0,9,1,10,2,11,3,12,4,13,5,14,6,15,7,16,8];

我需要在补间中使用它们,这是我正在执行此操作的功能,但我没有上面提到的 oder。

var pick_images = function(lights_arr,iterator,f)
{
  if(iterator < lights_arr.length)
  {
    iterator = iterator +1;
  }
    createjs.Tween.get(lieghts_arr[iterator]).to({alpha:0},200).wait(0).to({alpha:1},200).wait(100).call([f,lights_arr,f]);
pick_images(arr, i,pick_images);

我知道,如果我取 lights_arr.length 并将其除以 2,将其四舍五入,我会得到第二张图像,如 9、10、11 或 12。为此,我需要在每次循环后减去我使用的两个 elemets(图像(。

你知道我怎样才能在我的函数中工作吗?

这个怎么样?

var myarray = [0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16];
var select = [];
var step = 9;
var len = myarray.length;
for(var i = 0; i < len * step; i += step)
    select.push(myarray[i % len])
console.log(select) // [ 0, 9, 1, 10, 2, 11, 3, 12, 4, 13, 5, 14, 6, 15, 7, 16, 8 ]

只是稍微扩展/优化了 Georg 的代码以使其更具动态性,因为我认为他是一个非常简洁的解决方案:

var len = 17,
    myarray = Array.apply(null, {length: len}).map(Number.call, Number),
    select = [],
    step = Math.round(myarray.length / 2);
for(var i = 0; i < len * step; i += step) {
  select.push(myarray[i % len]);
}
console.log(select);

下面是生成填充整数的数组的代码。

var switch = false;
var selectedIndex = 0;
if(i < arr.length)
{
    selectedIndex = (switch) ? i : i + 9; 
    switch = !switch;
}

这样的事情应该可以做到,但可能会做得更整洁。请注意,未经测试且在我的 popo 顶部。

编辑:哦,对于要删除的图像,您可以使用拼接:

var arr = [0,1,2];
arr.splice(1,1); // position and how many to remove
output: arr = [0,2];

拼接 W3C 文档

var myarray = [0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16];
var select = [];
var position = 0;
while (position < myarray.length) {
  select.push(myarray[position]);
  if (select.length % 2) position += 9;
  else position -= 8;
}
alert(select);