您的当前位置:首页jQuery_渐隐式轮播效果插件封装

jQuery_渐隐式轮播效果插件封装

2024-12-09 来源:哗拓教育

使用 jQuery 封装一个渐隐式轮播效果插件。

效果图:

兼容性:


兼容性

插件参数说明:

  • autoPlay:自动切换的时间间隔(单位ms),不设定该参数slide不会自动切换。
  • speed:切换速度(单位ms)。
  • initialItem:初始化轮播元素索引,类型:number。
  • pagination:分页位置,类型:HTML 标签。
  • paginationNum:是否显示数字分页,类型:boolean,true 显示数字分页。
  • paginationClickable:点击分页是否切换,类型:boolean,true 可以切换。
  • arrow_left:切换到上一个轮播元素,类型:HTML 标签。
  • arrow_right:切换到下一个轮播元素,类型:HTML 标签。

HTML

<div class="slide_container slide_demo">
    <div class="slide_wrapper">
        <div class="slide_item" style="background-color: #4390ee;">item1</div>
        <div class="slide_item" style="background-color: #ff8604;">item2</div>
        <div class="slide_item" style="background-color: #49a430;">item3</div>
    </div>
    <div class="pagination"></div>
    <div class="arrow">
        <i class="arrow_left">left</i>
        <i class="arrow_right">right</i>
    </div>
</div>

CSS

.slide_container { position: relative; width: 600px; margin: 20px auto; }
.slide_item { font-size: 24px; line-height: 250px; position: absolute; top: 0; left: 0; overflow: hidden; width: 100%; text-align: center; }
.pagination { position: absolute; z-index: 1; bottom: 20px; width: 100%; text-align: center; }
.pagination span { display: inline-block; width: 20px; height: 20px; margin: 0 10px; cursor: pointer; border-radius: 50%; background-color: #fff; }
.pagination .active { background-color: #adadad; }
.arrow i { position: absolute; z-index: 1; top: 50%; display: inline-block; cursor: pointer; }
.arrow .arrow_left { left: 20px; }
.arrow .arrow_right { right: 20px; }

JS调用

<script src="jquery-1.8.3.min.js"></script>
<script src="LKSlideshow.js"></script>
<script>
$(function() {
    $(".slide_demo").LKSlideshow({
        autoPlay:3000,
        speed: 500,
        initialItem: 3,
        pagination: ".pagination",
        paginationNum: false,
        paginationClickable: true,
        arrow_left: ".arrow_left",
        arrow_right: ".arrow_right"
    });
});
</script>

JS封装插件

LKSlideshow.js

/**
 * Title: LKSlideshow
 * Version: 1.1.1
 * Description: plugin
 * Author: LiuZhenghe
 * Date: 2019-01-03
 */

(function($) {
    // What does the LKSlideshow plugin do?
    $.fn.LKSlideshow = function(options) {

        if (!this.length) {
            return this;
        };

        var opts = $.extend(true, {}, $.fn.LKSlideshow.defaults, options);

        this.each(function() {
            var $this = $(this);
            var slide_container = $(this).find('.slide_container');
            var slide_wrapper = $(this).find('.slide_wrapper');
            var slide_item = $(this).find('.slide_item');
            var pagination = $(opts.pagination);
            var paginationNum = opts.paginationNum;
            var paginationClickable = opts.paginationClickable;
            var page_text = "";
            var item_length = slide_item.length;
            var arrow_left = $(opts.arrow_left);
            var arrow_right = $(opts.arrow_right);
            var autoPlay;
            var speed = opts.speed; // 切换速度
            var initialItem = opts.initialItem; // 初始化索引
            // 不设置初始化索引值,或设置的值超过轮播元素的个数,默认为0。
            if (initialItem == null || initialItem > item_length - 1) {
                initialItem = 0;
            };
            // 设置初始化显示与隐藏的元素。
            slide_item.eq(initialItem).animate({
                opacity: "1"
            }, 0);
            slide_item.eq(initialItem).siblings().animate({
                opacity: "0"
            }, 0);

            // 动态设置轮播区域高度
            var slide_height = slide_item[0].clientHeight;
            slide_wrapper.css('height', slide_height);

            // 分页相关设置
            // 当不设置 paginationNum 的值或设置为 true 时,分页中添加数字。
            if (paginationNum != true) {
                for (var i = 1; i <= item_length; i++) {
                    page_text += "<span></span>";
                };
            } else {
                for (var i = 1; i <= item_length; i++) {
                    page_text += "<span>" + i + "</span>";
                };
            };
            // 动态添加分页
            pagination.html(page_text);
            // 给分页加当前样式
            var pagination_list = pagination.children('span');
            for (var i = 0; i < pagination_list.length; i++) {};
            $(pagination_list[initialItem]).addClass('active');

            // 切换主方法:
            // 传入两个参数:tag,page_index。
            // tag:"0"表示点击左箭头,"1"表示点击右箭头,"2"表示点击分页。
            // page_index:在主方法中无法获取被点击元素的索引值,永远是-1,所以需要传入一个参数来获得。
            function slideMove(tag, page_index) {
                // 清除定时器
                // 不清除定时器,就会创建出多个定时器,切换速度会越来越快。
                clearInterval(autoPlay);
                slide_item.stop(true, true); // 清除多次点击事件

                // 点击左箭头执行事件
                if (tag == 0) {
                    initialItem--;
                    if (initialItem < 0) {
                        initialItem = item_length - 1;
                    };
                };

                // 点击右箭头执行事件
                if (tag == 1) {
                    initialItem++;
                    if (initialItem > item_length - 1) {
                        initialItem = 0;
                    };
                };

                // 点击分页执行事件
                if (tag == 2) {
                    initialItem = page_index;
                };

                // 切换效果
                slide_item.eq(initialItem).animate({
                    opacity: "1"
                }, speed);
                slide_item.eq(initialItem).siblings().animate({
                    opacity: "0"
                }, speed);
                pagination_list.eq(initialItem).siblings().removeClass('active');
                pagination_list.eq(initialItem).addClass('active');

                // 自动轮播2
                // 当前位置改变后再次触发右箭头点击事件,此时就可以一直循环点击事件。
                if (typeof(opts.autoPlay) != "number") {
                    clearInterval(autoPlay);
                } else {
                    autoPlay = setTimeout(function() {
                        slideMove(1);
                    }, opts.autoPlay);
                };

            };

            // 自动轮播1
            // 触发第一次右箭头点击事件。
            // 此处做了一个判断,当调用该插件时,如果不设置 autoPlay 的值或设置为 fales 等其他值时,不执行自动轮播事件。
            if (typeof(opts.autoPlay) != "number") {
                clearInterval(autoPlay);
            } else {
                autoPlay = setTimeout(function() {
                    slideMove(1);
                }, opts.autoPlay);
            };

            // 点击左箭头
            arrow_left.click(function(event) {
                event.preventDefault();
                slideMove(0);
                return false;
            });

            // 点击右箭头
            arrow_right.click(function(event) {
                event.preventDefault();
                slideMove(1);
                return false;
            });

            // 点击分页
            // 加一个判断条件:当 paginationClickable 为 true 是,触发分页点击事件,默认无点击事件。
            if (paginationClickable == true) {
                pagination.on('click', 'span', function(event) {
                    event.preventDefault();
                    slideMove(2, $(this).index());
                });
            };

        });

        return this;
    };

    // default options
    $.fn.LKSlideshow.defaults = {
        autoPlay: null, // 自动轮播
        speed: null, // 速度
        initialItem: null, // 初始化索引
        pagination: null, //  分页
        paginationNum: null, // 数字分页
        paginationClickable: null, // 点击分页切换
        arrow_left: null, // 点击左箭头
        arrow_right: null // 点击右箭头
    };

})(jQuery);
显示全文