Изображения из Backstretch(backstretch.js) на одной странице переходят на обратную страницу другой страницы в Durandal.js

Я использовал Durandal.js для моего SPA. Мне нужно иметь слайд-шоу изображений в качестве фона на определенных страницах, для чего я использую jquery-backstretch. Я загружаю изображения из моего веб-интерфейса. Все работает нормально при навигации между страницами с нормальной скоростью. Но когда я очень быстро перехожу с одной из страниц, на которой имеется обратное растяжение, на другую с обратным растяжением, изображения с обратного растяжения на первой странице также ползут на второй странице. Когда я отлаживал, только правильные изображения передавались на вторую страницу. А также слайд-шоу не запускается в надлежащем интервале. Так что это должны быть оба вызываемых backstretches.

Пожалуйста, скажите мне, как я могу предотвратить повторное появление предыдущего backstretch. Вот соответствующие фрагменты кода.

Это код моей модели первой страницы (с обратным растяжением).

var id = 0;
var backstetcharray;
function loadbackstretchb() {
backstetcharray = new Array();
$.each(that.products, function (i, item)
{

    if(item.ProductBackImage != "")
    {
        backstetcharray.push("xxxxxxxxxx" + item.ProductBackImage);
    }

}
);
$.backstretch(backstetcharray, { duration: 5000, fade: 1500 });
}
var that;
define(['plugins/http', 'durandal/app', 'knockout'], function (http, app, ko) {
var location;
function callback() {
    window.location.href = "#individual/"+id;
    // this.deactivate();
};
return {
    products: ko.observableArray([]),
    activate: function () {
        currentpage = "products";
        that = this;
        return http.get('yyyyyyyyyyyyyyy').then(function (response) {
            that.products = response;
            loadbackstretchb();
        });

    },
    attached: function () {
        $(document).ready(function () {
            $('.contacticon').on({
            'mouseenter': function () {
                $(this).animate({ right: 0 }, { queue: false, duration: 400 });
            },
            'mouseleave': function () {
                $(this).animate({ right: -156 }, { queue: false, duration: 400 });
            }
        });
        });

        $(document).ready(function () {
            $(".mainmenucont").effect("slide", null, 1000);
        });
        //setTimeout($(".mainmenucont").effect("slide", null, 1000), 1000);

        $(document).on("click", ".ind1", function (e) {
           // alert("ind1");
            id = e.target.id;
           // $(".mainmenucont").effect("drop", null, 2000, callback(e.target.id));
            $('.mainmenucont').hide('slide', { direction: 'left' }, 1000, callback);
        });
    }
}
});

Это код моей модели второй страницы (с обратным растяжением) (туда, куда я направляюсь)

var recs;
var open;
var i, count;
var backstetcharray;
function loadbackstretchc() {
backstetcharray = new Array();
$.each(recs, function (i, item) {

    if (item.BackgroundImage != "") {
        backstetcharray.push("xxxxxxxxxx" + item.BackgroundImage);
    }

}
);
$.backstretch(backstetcharray, { duration: 5000, fade: 1500 });
}
var that;
define(['plugins/http', 'durandal/app', 'knockout'], function (http, app, ko) {
var system = require('durandal/system');
var location;
function menucallback() {
    window.location.href = location;
    // this.deactivate();
};


return {
    activate: function (val) {
        currentpage = "recipes";
        open = val;
       that = this;
        var pdts;
        recs;
        var recipeJson = [];
         http.get('yyyyyyyyyyyyyy').then(function (response) {
            pdts = response;
            http.get('yyyyyyyyyyyy').then(function (response1) {
                recs = response1;
                loadbackstretchc();
                $.each(pdts, function (i, item) {
                    var json = [];
                    $.each(recs, function (j, jtem) {
                        if (item.DocumentTypeId == jtem.BelongstoProduct) {
                            json.push(jtem);
                        }
                    });

                    jsonitem = {}
                    jsonitem["product"] = item.ProductName;
                    jsonitem["link"] = "#" + item.UmbracoUrl;
                    jsonitem["target"] = item.UmbracoUrl;
                    jsonitem["recipes"] = json;
                    recipeJson.push(jsonitem);

                });

                // that.products = recipeJson;
                count = recipeJson.length;
                i = 0;
                return that.products(recipeJson);

            });
        });
    },
    attached: function(view) {
        $(document).ready(function () {
            $('.contacticon').on({
                'mouseenter': function () {
                    $(this).animate({ right: 0 }, { queue: false, duration: 400 });
                },
                'mouseleave': function () {
                    $(this).animate({ right: -156 }, { queue: false, duration: 400 });
                }

            });



        });
        $(document).ready(function () {
            $(".mainmenucont").effect("slide", null, 1000);
        });

        $(document).on("click", ".recipeclick", function (e) {
            console.log(e);
            location = "#recipe/" + e.target.id;
            $('.mainmenucont').hide('slide', { direction: 'left' }, 1000, menucallback);
        });



        $(document).on("click", ".locclick", function (e) {
            if (e.handled != true) {
                if (false == $(this).next().is(':visible')) {
                    $('#accordion ul').slideUp(300);
                }
                $(this).next().slideToggle(300);
                e.handled = true;
            }
        });
    },
    products: ko.observableArray([]),
    expand: function() {
        ++i;
        if (i == count) {
            $("#" + open).addClass("in");

        }
    }
};

});

0 ответов

Другие вопросы по тегам