假设我们有一个长度为 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 语句来完成,我正在寻找一种方法来使用某种数学公式,也许可以
- 将任何负数转换为 0;
- 保留任何正数;
- 使用数组的长度来决定何时返回上限。
更新
我同意 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/