slider.goToNextSlide()滑块未定义bxSlider

Mat*_*ord 6 javascript sharepoint jquery bxslider

我的一些工作一直存在问题,我现在离开的同事为了实施而写了bxSlider.
我在修复另一个问题时确定了问题bxSlider停止工作2天前没有代码更改.

我间歇地得到:

TypeError: slider is undefined   .../Pages/Home.aspx   Line 1023
Run Code Online (Sandbox Code Playgroud)

这是一个SharePoint 2013 webpart实现,而不是真正重要的问题,但只是给出一些背景知识.

var slider= $('#slider2').bxSlider({
        auto: true,           
        controls: false,
        pager:false,
        pause: 10000,
        slideWidth: (sir ? sirina:300),
        slideHeight: 450,
        randomStart: true,
        autoHover: true,
        onSliderLoad: function (currentIndex) {
            slider.goToNextSlide();
        },

        onSlideNext: function (slide, oldIndex, newIndex)
        {
            var current = slider.getCurrentSlide();
            var id = slide[0].id;
            var prev = slide.prev();
            var next = slide.next();
            var previd = prev[0].id;
            var nextid = next[0].id;
            displayImages(id, previd, nextid)
        },

        onSlidePrev: function (slide, oldIndex, newIndex)
        {
            var current = slider.getCurrentSlide();
            var id = slide[0].id;
            var prev = slide.prev();
            var next = slide.next();
            var previd = prev[0].id;
            var nextid = next[0].id;
            displayImages(id, previd, nextid)
        }        
    });
Run Code Online (Sandbox Code Playgroud)

我开始在bxSlider网页上查看和研究滑块以获得一些了解.我注意到的第一件事是对.bxSlider的调用需要在$(document).ready(function(){.我实现的实现不是,所以我在原始函数周围添加了.这似乎有意义,因为这是间歇性的让我感到震惊,这取决于#slider2的DOM元素是否已经加载.它永远不会在以前从未加载过该网站的机器上的全新浏览器上工作,因此缓存部分页面可加快负载并获得在此脚本加载之前页面上的#slider2,但仍然没有区别.

所以开始阅读bxSlider网页上的示例,特别注意这个例子. http://bxslider.com/examples/custom-next-prev-selectors 它使用一种完全不同的技术,以使用户点击到下一个或上一张幻灯片.

所以我尝试重新设计以遵循这种模式.

$('#slider2').bxSlider({
        auto: true,           
        controls: false,
        pager:false,
        pause: 10000,
        slideWidth: (sir ? sirina:300),
        slideHeight: 450,
        randomStart: true,
        autoHover: true,
        nextSelector: '#leftFr',
        prevSelector: '#rightFr',

        onSlideNext: function (slide, oldIndex, newIndex)
        {
            var id = slide[0].id;
            var prev = slide.prev();
            var next = slide.next();
            var previd = prev[0].id;
            var nextid = next[0].id;
            displayImages(id, previd, nextid)
        },

        onSlidePrev: function (slide, oldIndex, newIndex)
        {
            var id = slide[0].id;
            var prev = slide.prev();
            var next = slide.next();
            var previd = prev[0].id;
            var nextid = next[0].id;
            displayImages(id, previd, nextid)
        }         
    });
Run Code Online (Sandbox Code Playgroud)

这消除了对滑块变量的需要,但引入了不同的问题,从而消除了这个问题.首先,下一个和上一个按钮不起作用,因为文档说它应该,并且在页面的初始加载时,滑块未填充,也没有使用正确的文本设置下一个和上一个按钮.这就是原始onSliderLoad函数通过立即更改滑块的功能.

onSlideLoad事件的第一个增强是当前滑块的索引.我还没有找到如何使用这个值正确填充滑块:所以我做了一些关于如何使用.bxSlider方法的研究,滑块变量看起来似乎是正确的方法. bx slider:如何在单击默认bx寻呼机后继续自动滑动?.所以我将代码还原并取消了我的更改,但仍未找到"slider is undefined"的解决方案.这是完整的文档就绪功能,因为它与初始问题一致:

$(document).ready(function () {

    $("iframe").contents().find(".timeline").css("background", 'rgba(0,0,0,0)');
    changeFeeds();
    var t2 = JSVar;
    var sirina = w;
    var dolzina = h;
    var sir=false;
    var dol=false;

    //read more...starts
    var MORE = "... More...", LESS = " Less...";
    $(".moreAdHoc").each(function () {

        var $ths = $(this),
        txt = $ths.text();
        var p = $ths.find('.pid');
        var idValue = p.text();
        $ths.text("");            
        $ths.append($("<span>").text(txt.substr(0, 300)));
        $ths.append($("<span>").text(txt.substr(300, txt.length)).hide());
        $ths.append(
            $("<a class=morelink onclick=openNewsContent(" + idValue + ")>").text(MORE).click(function () {
                var $ths = $(this);
                if ($ths.text() == MORE) { }
                else {
                    $ths.prev().hide();
                    $ths.text(MORE);
                }
            })
        );
    });

    $(".moreWhatsNew").each(function () {

        var $ths = $(this),
        txt = $ths.text();
        var p = $ths.find('.pwhatsNewid');
        var p1 = $ths.find('.pwhatsNewSite');
        var idValue = p.text();
        var siteValue = p1.text();
        $ths.text("");           
        $ths.append($("<span>").text(txt.substr(0, 300)));
        $ths.append($("<span>").text(txt.substr(300, txt.length)).hide());
        $ths.append(
            $("<a class=morelink onclick=openWhatsNewNewsContent(" + idValue + ",'" + siteValue + "')>").text(MORE).click(function () {
                var $ths = $(this);
                if ($ths.text() == MORE) { }
                else {
                    $ths.prev().hide();
                    $ths.text(MORE);
                }
            })
        );
    });
    //read more...ends

    var slider= $('#slider2').bxSlider({
        auto: true,           
        controls: false,
        pager:false,
        pause: 10000,
        slideWidth: (sir ? sirina:300),
        slideHeight: 450,
        randomStart: true,
        autoHover: true,
        onSliderLoad: function (currentIndex) {
            slider.goToNextSlide();
        },

        onSlideNext: function (slide, oldIndex, newIndex)
        {
            var current = slider.getCurrentSlide();
            var id = slide[0].id;
            var prev = slide.prev();
            var next = slide.next();
            var previd = prev[0].id;
            var nextid = next[0].id;
            displayImages(id, previd, nextid)
        },

        onSlidePrev: function (slide, oldIndex, newIndex)
        {
            var current = slider.getCurrentSlide();
            var id = slide[0].id;
            var prev = slide.prev();
            var next = slide.next();
            var previd = prev[0].id;
            var nextid = next[0].id;
            displayImages(id, previd, nextid)
        }        
    });

    $('.pronext').click(function () {
        slider.goToNextSlide();            
        return false;
    });


    $('.proprev').click(function () {
        slider.goToPrevSlide();
        return false;
    });

    $('#rightFr').click(function () {
        slider.goToNextSlide();
        return false;
    });

    $('#leftFr').click(function () {
        slider.goToPrevSlide();
        return false;
    });
});
Run Code Online (Sandbox Code Playgroud)

小智 -1

对于您的第二个( $('#slider2').bxSlider )解决方案,您是否尝试添加 startSlide 选项(startSlide: 0)来准确指定要从哪个项目开始?

如果这仍然不起作用,您能否指定“...下一个和上一个按钮不能像文档所说的那样工作...”的含义?