js圖片預加載

// 獲取文件名稱後綴 、不帶後綴
function getFilePath(filePath){
    var path = [];
    var pos = filePath.lastIndexOf('.');
    path['fileExt'] = filePath.substring(pos);   //獲取後綴
    path['fileName'] = filePath.substring(0,pos);//獲取文件名,不帶後綴
    return path;
}

//實現一系列圖片的預加載
//參數sources:圖片信息關聯數組
//參數callback:回調函數——圖片預加載完成後當即執行此函數。
function preloadImages(sources,callback){   
    var newimages=[], 
        loadedimages=0;
    var sources = (typeof sources!="object")? [sources] : sources;
    function imageloadpost(){
        loadedimages++;
        if (loadedimages == sources.length){
            callback && callback(newimages);
        }
    }
    for (var i=0; i<sources.length; i++){
        newimages[i] = new Image();
        newimages[i].onload=function(){
            imageloadpost();
        };
        newimages[i].onerror=function(){
            imageloadpost();
        };
        newimages[i].src = sources[i];
    };
}

function LoadImages(opts){
    this.isFirst = true;
    this.currPage = 1;
    this.pageNum = opts.pageNum;
    this.imgData = {
        currPage:null,
        prevPage:null,
        nextPage:null
    };
}
LoadImages.prototype.init = function(){//初始化
    this.loadData(1,0);
};
LoadImages.prototype.goTo = function(toType){
    var _self = this;
    if(toType == 1){//下一頁
        _self.imgData.prevPage = _self.imgData.currPage;
        _self.imgData.currPage = _self.imgData.nextPage;
        _self.currPage++;
        _self.showImg(1);
    }else if(toType == -1){//上一頁
        _self.imgData.nextPage = _self.imgData.currPage;
        _self.imgData.currPage = _self.imgData.prevPage;
        _self.currPage--;
        _self.showImg(-1);
    }
};
LoadImages.prototype.showImg = function(showType){//顯示圖片
    var _self = this;
    var data = _self.imgData.currPage;
    if(_self.currPage == 1){
        $(".picwarp span.pre").addClass('hide');
    }else{
        $(".picwarp span.pre").removeClass('hide');//隱藏上一頁按鈕
    }
    if(data.num <= _self.pageNum*_self.currPage){
        $(".picwarp span.next").addClass('hide');
    }else{
        $(".picwarp span.next").removeClass('hide');//隱藏下一頁按鈕
        if(showType == 1 && ((_self.currPage+1) <= Math.ceil(data.num/_self.pageNum))){
            this.loadData(_self.currPage+1,1);
        }else if(showType == -1 && _self.currPage-1 >= 1){
            this.loadData(_self.currPage-1,-1);
        }
    }
    var list = data.urls;
    var curdd = null;
    var currPath = null; 
    for(var i=0;i<35 && i<list.length && i<_self.pageNum;i++){//遍歷圖片並顯示
        currPath = getFilePath(list[i][0]);
        curdd = $('.moreImg dd:eq('+i+')');
        curdd.find('a').attr('href',list[i][0]);
        curdd.find('img').attr('src',currPath['fileName']+'s'+currPath['fileExt']);
    }
};
LoadImages.prototype.preLoadImg = function(list,callback){//預加載圖片
    var currPath = null; 
    var imgageArr = [];
    for(var i=0;i<list.length;i++){
        imgageArr.push(list[i][0]);
        currPath = getFilePath(list[i][0]);
        imgageArr.push(currPath['fileName']+'s'+currPath['fileExt']);
    }
    preloadImages(imgageArr,callback);
};
LoadImages.prototype.loadData = function(pageIdx,loadType){//加載圖片
    var _self = this;
    $.ajax({
        type : 'POST',
        url : xxx.getPageImgList,
        data : {
            pageNum:_self.pageNum,
            currentPage:pageIdx
        },
        dataType : 'json',
        success : function(data){
            if(loadType == 0){
                _self.imgData.currPage = data;
                _self.preLoadImg(data.urls,_self.showImg(1));
            }else if(loadType == 1){
                _self.imgData.nextPage = data;
                _self.preLoadImg(data.urls);
            }else if(loadType == -1){
                _self.imgData.prevPage = data;
                _self.preLoadImg(data.urls);
            }
        }
    });
};
//建立實例
var loadImgPage = null;
    loadImgPage = new LoadImages({pageNum:35});
相關文章
相關標籤/搜索