javascript - 拼接方法不从数组中删除项目

标签 javascript arrays splice

我正在尝试实现一个函数,该函数接受三个参数(最小值、最大值、步长)并生成从最小值到最大值的整数范围,以及步长。第一个整数是最小值,第二个是范围的最大值,第三个是步长。

下面是它应该是什么样子的一个例子: generateRange(2, 10, 2) 应该返回 [2,4,6,8,10] 的数组。

我正在使用 splice 方法删除数组中大于最大参数的任何现有元素。

function generateRange(min, max, step) {
  var arr = [];
  var count = min;
  for (var i = 0; i < max / step; i++) {
    arr[i] = count;
    count = count + step;
    arr[i] > max ? arr.splice(i, 1) : arr[i];
  }
  return arr;
}

console.log(generateRange(2, 10, 2));

每当我 console.log 我的结果时,我都会在最后一项之后得到一堆逗号......所以它看起来像这样:[2,4,6,8,10, , , , ]

它似乎没有删除项目。我错过了什么?谢谢!

最佳答案

三元运算符有点奇怪,因为不存储表达式。它通过删除太大的值来修复数组。这一次有效,但如果有第二次,i 将增加,并且通过分配给 arr[i],数组的长度再次好像有之前没有执行拼接(i-1 索引处的未定义值除外)。

最好在分配超出范围的值之前退出循环。在这种情况下继续循环是没有意义的。

所以让 count 变量成为你的循环变量和条件:

function generateRange(min, max, step){
    var arr = [];
    for(var count = min; count <= max; count+=step){
        arr.push(count);
    }
    return arr;
}

var res = generateRange(2, 10, 2);

console.log(res);

可读性较差但较短的 ES6 版本是:

function generateRange(min, max, step){
    return Array.from(Array(Math.floor((max-min)/step)+1), (x,i) => min+i*step);
}

let res = generateRange(2, 10, 2);

console.log(res);

关于javascript - 拼接方法不从数组中删除项目,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40031579/

相关文章:

javascript - 使用javascript将html内容转换为图像

javascript - 使用 CasperJS 提交表格内容

javascript - 使用 Array.filter() 删除多个数组值

java - 将数组中的值放入 map

java - Java中的数组修改(更改数组 "resolution")

javascript - 在每个值的中间填充 JavaScript 数组

javascript - JQuery 创建 HTML 无法正常工作

javascript - SailsJS 日志请求参数

c++ - std::list::splice() 和 std::forward_list::splice_after() 在 C++11 中声明为 noexcept 吗?

javascript - 使用 javascript 中的 splice 删除嵌套数组中的项目