javascript - 如果索引超出数组范围,则将索引设置为最近的边界

标签 javascript arrays algorithm math

假设我们有一个长度为 1 到 ?? 的数组

我们有一种方法可以通过单击向上或向下导航的按钮来向上或向下导航此数组,该按钮显示在 DOM 中(想想分页)。

我们希望导航在超出下限时停止,或者在导航超出上限时停止。

当我们到达下限时,我们会通过值 -1

知道这一点

当我们达到上限时,我们将通过值 ( > array.length - 1 ) 知道这一点。

我们的函数接受参数索引,如图所示

function goToChapter( index ){
  // compute value of index to within bounds.
  return array[ index ];
}

假设我们想要做的就是使用计算出的边界索引从返回的数组中获取一个值。

Examples

var array ["chapZero", "chapOne", "chapTwo", "chapThree"];

goToChapter( 2 );
=> "chapTwo;

goToChapter( 4 );
=> "chapThree"; // because four is out of upper bound so index became three.

goToChapter( -1 );
=> "chapZero"; // because -1 is our of lower bound so index became zero.

我意识到这可以通过一些 if 语句来完成,我正在寻找一种方法来使用某种数学公式,也许可以

  1. 将任何负数转换为 0;
  2. 保留任何正数;
  3. 使用数组的长度来决定何时返回上限。

更新

我同意 Andand 的回答。我已经添加了足够多的内容,可以将解决方案复制粘贴到控制台中,如果您觉得这有帮助并想对其进行测试的话。

var array = [0,1,2,3,4];

function goToChapter( index, array ){
  return array[(Math.min( array.length - 1, Math.max( 0, index )))];
}

goToChapter( -1, array ); => 0;

goToChapter( 3, array ); => 3;

goToChapter( 8, array ); => 4;

谢谢安安。

注意:

我也发现这很有帮助,但没有那么快。

function setWithinArrayBounds( index, array ){
  return !!index ? 0 : index > ( array.length - 1 ) ? ( array.length - 1 ) : index;
}

最佳答案

这称为限制值以将其限制在指定范围内。

您可以像这样使用 min()max():

function goToChapter(array, index ){
    myIndex = Math.min(array.length-1, Math.max(0, index));
    return array[ myIndex ];
}

另一种方法是使用嵌套的三元运算符,例如

function goToChapter(array, index ){
    myIndex = index < 0 
        ? 0
        : index >= array.length
            ? array.length - 1
            : index;
    return array[ myIndex ];
}

您也可以使用 if 语句

function goToChapter(array, index ){
    if (index < 0) {
        myIndex = 0;
    } else if (index >= array.length) {
        myIndex = array.length-1;
    } else {
        myIndex = index;
    }

    return array[ myIndex ];
}

或者使用顺序 if 语句的变体可以是

function goToChapter(array, index ){
    myIndex = index;

    if (myIndex < 0) {
        myIndex = 0;
    }

    if (myIndex >= array.length) {
        myIndex = array.length-1;
    }

    return array[ myIndex ];
}

关于javascript - 如果索引超出数组范围,则将索引设置为最近的边界,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32019252/

相关文章:

javascript - 动态添加边框时防止元素移动

javascript - 使用 jQuery 和 CSS3 的 TranslateX() 在将父元素滚动到 View 中时显示元素

javascript - 如果文本写入输入然后被删除,blur() 不起作用 - jQuery

java - 合并社区并通过其成员找到社区

java - 制作电脑艺术的策略

javascript - 在不扭曲列数据的情况下添加表格列分隔符?

php - 根据类型对混合数组进行排序

如果作为数组或对象传递,PHP 变量变量不显示

php - 处理对象数组时如何避免循环中的array_merge

c - 以内存效率管理二叉树中的重复项