开发者社区> 问答> 正文

封装了一个渐隐渐现的轮播图组件,请问如何解决 第一次切换效果不正确?

封装了一个渐隐渐现的轮播图组件,但是只有在第一次点击向左或向右按钮时,切换效果都不是渐隐渐现,其他时候切换效果都正确

轮播图组件代码

//轮播图组件
;(function($){

var Carousel = function(poster){

    var self = this;
    this.poster = poster;
    this.posterMain = poster.find(".slider-list");
    this.posterItem = poster.find(".slider-panel");
    this.posterSize = this.posterItem.length;
    this.prevBtn = poster.find(".slider-page .prev");
    this.nextBtn = poster.find(".slider-page .next");
    this.navSpan = poster.find(".pic-num span");
    this.isanimated = true;
    this.index = 0;
    //默认参数
    this.setting = {
        "autoPlay" : false,
        "speed" : 200,
        "delay" : 3000,
        "hasnav" : false
    };

    $.extend(this.setting,this.getSetting());

    //prevBtn
    this.prevBtn.click(function(){
        if(self.isanimated){
            self.index --;
            if(self.index < 0 ){
                self.index = self.posterSize -1;
            }
            self.showImg(self.index);
        }
    });

    //nextBtn
    this.nextBtn.click(function(){
        if(!self.isanimated){
            return;
        }
        self.index ++;
        if(self.index >= self.posterSize ){
            self.index = 0;
        }
        self.showImg(self.index);
    });

    //判断自动播放
    if(this.setting.autoPlay){
        this.autoPlay();
    };
};

Carousel.prototype = {

    //自动播放
    autoPlay : function(){
        var self = this;
        if(!self.isanimated){
            return;
        }
        self.index ++;
        if(self.index >= self.posterSize ){
            self.index = 0;
        }
        self.showImg(self.index);
        this.timer = window.setInterval(function(){
            self.autoPlay();
        },this.setting.delay);
    },

    //获取设置的参数
    getSetting : function(){
        var setting = this.poster.attr("data-setting");
        if( setting && setting != ""){
            return $.parseJSON(setting);
        }
        return {};
    },

    //showImg
    showImg : function(index){
        var _this = this;
        this.isanimated = false;
        this.posterItem.eq(index).addClass("on").animate({opacity:1,"z-index":0},this.speed,function(){
            _this.isanimated = true;
        }).siblings().removeClass("on").animate({opacity:0,"z-index":-1},this.speed);
        $(".pic-num span").eq(index).addClass("on").siblings(".pic-num span").removeClass("on");
    }
}

//初始化函数
Carousel.init = function(poster){
    var _this = this;
    poster.each(function(){
        new _this($(this));
    });
}

window["Carousel"] = Carousel;

})(jQuery);
html代码

screenshot

css代码
screenshot

请问呢该如何解决呢?求大神

展开
收起
小旋风柴进 2016-05-30 13:23:45 3136 0
1 条回答
写回答
取消 提交回答
  • ~1.this.index = -1;~
    ~2.data-setting='{"width":1000,"height":200,"autoPlay":true}'~

    构造函数的默认先手动调用一下:

    self.showImg(0);
    先将opacity属性初始化到元素上~~~

    2019-07-17 19:20:24
    赞同 展开评论 打赏
问答分类:
问答地址:
问答排行榜
最热
最新

相关电子书

更多
动态、高效,蚂蚁动态卡片的内核逻辑 立即下载
3D动画的菜谱式灯光与云渲染 立即下载
《 优酷APP全量支持“暗黑模式” 设计与技术完整总结》 立即下载