Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/javascript/437.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Javascript 未捕获类型错误:无法读取属性';包含';空的_Javascript_Jquery - Fatal编程技术网

Javascript 未捕获类型错误:无法读取属性';包含';空的

Javascript 未捕获类型错误:无法读取属性';包含';空的,javascript,jquery,Javascript,Jquery,我目前正在一个项目中工作,在该项目中,我在总体网站中使用以下滑块: 对于我目前正在处理的特定页面,我还利用了Walter Zorns的拖放图像库。(链接) 现在,当我开始使用使用D&D库所需的SET\u DHTML函数时,我的滑块开始抛出错误: 未捕获类型错误:无法读取null的属性“contains” 给定的行号将我发送到以下行: if($(itemsSpan[currNo]).css('bottom')==0{ 其中包含以下代码: s3Slider = function(id, va

我目前正在一个项目中工作,在该项目中,我在总体网站中使用以下滑块:

对于我目前正在处理的特定页面,我还利用了Walter Zorns的拖放图像库。(链接)

现在,当我开始使用使用D&D库所需的
SET\u DHTML
函数时,我的滑块开始抛出错误:

未捕获类型错误:无法读取null的属性“contains”

给定的行号将我发送到以下行:

if($(itemsSpan[currNo]).css('bottom')==0{

其中包含以下代码:

   s3Slider = function(id, vars) {       

    var element     = this;
    var timeOut     = (vars.timeOut != undefined) ? vars.timeOut : 2000;
    var current     = null;
    var timeOutFn   = null;
    var faderStat   = true;
    var mOver       = false;
    var items       = $("#sliderContent .sliderTopstory");
    var itemsSpan   = $("#sliderContent .sliderTopstory span");

    items.each(function(i) {

        $(items[i]).mouseover(function() {
           mOver = true;
        });

        $(items[i]).mouseout(function() {
            mOver   = false;
            fadeElement(true);
        });

    });

    var fadeElement = function(isMouseOut) {
        var thisTimeOut = (isMouseOut) ? (timeOut/2) : timeOut;
        thisTimeOut = (faderStat) ? 10 : thisTimeOut;
        if(items.length > 0) {
            timeOutFn = setTimeout(makeSlider, thisTimeOut);
        } else {
            console.log("Poof..");
        }
    }

    var makeSlider = function() {
        current = (current != null) ? current : items[(items.length-1)];
        var currNo      = jQuery.inArray(current, items) + 1
        currNo = (currNo == items.length) ? 0 : (currNo - 1);
        var newMargin   = $(element).width() * currNo;
        if(faderStat == true) {
            if(!mOver) {
                $(items[currNo]).fadeIn((timeOut/6), function() {
                 /* This line ->   */if($(itemsSpan[currNo]).css('bottom') == 0) {
                        $(itemsSpan[currNo]).slideUp((timeOut/6), function( ) {
                            faderStat = false;
                            current = items[currNo];
                            if(!mOver) {
                                fadeElement(false);
                            }
                        });
                    } else {
                        $(itemsSpan[currNo]).slideDown((timeOut/6), function() {
                            faderStat = false;
                            current = items[currNo];
                            if(!mOver) {
                                fadeElement(false);
                            }
                        });
                    }
                });
            }
        } else {
            if(!mOver) {
                if($(itemsSpan[currNo]).css('bottom') == 0) {
                    $(itemsSpan[currNo]).slideDown((timeOut/6), function() {
                        $(items[currNo]).fadeOut((timeOut/6), function() {
                            faderStat = true;
                            current = items[(currNo+1)];
                            if(!mOver) {
                                fadeElement(false);
                            }
                        });
                    });
                } else {
                    $(itemsSpan[currNo]).slideUp((timeOut/6), function() {
                    $(items[currNo]).fadeOut((timeOut/6), function() {
                            faderStat = true;
                            current = items[(currNo+1)];
                            if(!mOver) {
                                fadeElement(false);
                            }
                        });
                    });
                }
            }
        }
    }

    makeSlider();

};  
为什么会抛出此错误


谢谢。

我认为你的问题在于这两行:

var currNo = jQuery.inArray(current, items) + 1
currNo = (currNo == items.length) ? 0 : (currNo - 1);
如果jQuery在数组中找不到该项,它将向您发送一个值-1(在顶行),该值将更改为0,因为您添加了1。现在,如果第二行的currNo为0,它将把它更改回-1,这将返回未定义的值。可以尝试将其更改为:

var currNo = jQuery.inArray(current, items);
if (currNo === items.length - 1) {
    currNo = 0;
}

我不确定这是否是问题所在,但如果这不是您当前遇到的问题,我可以看到这会成为一个问题。

我有一个水晶球。我现在去问您的代码,以及我是否在我的生日收到了非常好的礼物。多一些代码,而不仅仅是一行代码会很有帮助。也许可以将文件放在要点中?或者至少向我们展示deitemsSpan的定义?@MikeS。是的,我现在包含了更多的代码。另外,
if($(itemsSpan[currNo]).css('bottom'))
存在于两个不同的行中,哪一行?html和css看起来如何?谢谢,它解决了错误!但是现在每当我加载页面时,我看到它,几秒钟后它就变成了一个白色页面。这可能与这个问题有关吗?与您遇到的错误无关我不认为,我相信它与fadeElement函数更相关的是您设置的超时。