jQuery处理未定义的数组值

时间:2013-01-16 20:18:53

标签: jquery arrays class variables undefined

我正在查找数组值以来回滑动滑块,并且在我的逻辑中遇到了关于未定义值的漏洞。就目前而言,我查找数组中的当前幻灯片,添加或减去数组中的位置,如果该值存在,则更新位置。但是,如果数组中的值不存在(即数组中有3个对象并且滑块试图查找#4),则它会抛出类型错误。

需要一种更好的方式来说“如果价值存在,那么更新。”看起来很简单,但我没有想到一个好的解决方案。

我想我可以很容易地摆脱update变量,但我认为在数组中查找一次值并将其保存以用于body类更新是很好的,知道我的意思吗? / p>

请参阅下面的代码,谢谢!

function slide(direction){

/* Get Current */

    var current = $bod.attr('class'),
        next,
        update;

/* Navigate */

    if (direction === 'right'){

        next = $current + 1;

    } else if (direction === 'left'){

        next = $current - 1;

    } else if (direction === 'home'){

        next = $home;
    }

/* Update */

    // Issue is here. If the next slide is undefined, everything crashes

    update = $slides[next].slide;

    // Was trying to address the issue with this line:

    if (update){

        $bod.removeClass(current).addClass(update);

        $current = next;
    }
}

2 个答案:

答案 0 :(得分:1)

请尝试以下操作。

update = $slides[next] ? $slides[next].slide : false;

答案 1 :(得分:1)

你应该检查边界。

if ((direction === 'right') && ($current < $slides.length - 1)){
  next = $current + 1;
} else if ((direction === 'left') && ($current > 0)){
  next = $current - 1;
} else if (direction === 'home'){
  next = $home;
}