JQuery реализует эффекты светового короба
JQuery реализует эффекты светового короба

Позвольте мне поделиться с вами эффектом светового короба, основанным на JQuery. Эффект следующий:

В основном используется плагин jquery-rebox.js. Ниже приведена реализация кода. 

Язык кода:javascript
копировать
<!DOCTYPE html>
<html>

<head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <title>JQuery-reboxРеализовать эффекты светового короба</title>
    <link rel="stylesheet" href="css/jquery-rebox.css">
    <script src="js/jquery.min.1.11.1.js"></script>
    <script src="js/jquery-rebox.js"></script>
</head>

<body>
    <div id="gallery" class="gallery">
        <!-- Изображение в href — это большое изображение, а изображение в src — маленькое. -->
        <a href="images/0.jpg" title="Caption for image A">
            <img src="images/1.jpg">
        </a>
        <a href="images/2.jpg" title="Caption for image B">
            <img src="images/3.jpg">
        </a>
        <a href="images/4.jpg" title="Caption for image C">
            <img src="images/5.jpg">
        </a>
        <a href="images/6.jpg" title="Caption for image D">
            <img src="images/7.jpg">
        </a>
    </div>
    <script>
        $('#gallery').rebox({ selector: 'a' });
    </script>
</body>

</html>

Этот плагин сейчас сложно найти в Интернете, поэтому я представляю его вам. Ниже приведен код плагина Jquery-rebox.js.

Язык кода:javascript
копировать
(function ($) {
    $.rebox = function ($this, options) {
        this.settings = $.extend(true, {}, $.rebox.defaults, options);
        this.$el = $this;      // parent container holding items
        this.$box = null;      // the lightbox modal
        this.$items = null;    // recomputed each time its opened
        this.idx = 0;          // of the $items which index are we on
        this.enable();
    };

    $.rebox.defaults = {
        theme: 'rebox',        // class name parent gets (for your css)
        selector: null,        // the selector to delegate to, should be to the <a> which contains an <img>
        prev: '&larr;',        // use an image, text, whatever for the previous button
        next: '&rarr;',        // use an image, text, whatever for the next button
        loading: '%',          // use an image, text, whatever for the loading notification
        close: '&times;',      // use an image, text, whatever for the close button
        speed: 400,            // speed to fade in or out
        zIndex: 1000,          // zIndex to apply to the outer container
        cycle: true,           // whether to cycle through galleries or stop at ends
        captionAttr: 'title',  // name of the attribute to grab the caption from
        template: 'image',     // the default template to be used (see templates below)
        templates: {           // define templates to create the elements you need function($item, settings)
            image: function ($item, settings, callback) {
                return $('<img src="' + $item.attr('href') + '" class="' + settings.theme + '-content" />').load(callback);
            }
        }
    };

    $.rebox.setDefaults = function (options) {
        $.rebox.defaults = $.extend(true, {}, $.rebox.defaults, options);
    };

    $.rebox.lookup = { i: 0 };

    $.extend($.rebox.prototype, {
        enable: function () {
            var t = this;

            return t.$el.on('click.rebox', t.settings.selector, function (e) {
                e.preventDefault();
                t.open(this);
            });
        },
        open: function (i) {
            var t = this;

            // figure out where to start
            t.$items = t.settings.selector === null ? t.$el : t.$el.find(t.settings.selector);
            if (isNaN(i)) {
                i = t.$items.index(i);
            }

            // build the rebox
            t.$box = $('<div class="' + t.settings.theme + '" style="display:none;">' +
                '<a href="#" class="' + t.settings.theme + '-close ' + t.settings.theme + '-button">' + t.settings.close + '</a>' +
                '<a href="#" class="' + t.settings.theme + '-prev ' + t.settings.theme + '-button">' + t.settings.prev + '</a>' +
                '<a href="#" class="' + t.settings.theme + '-next ' + t.settings.theme + '-button">' + t.settings.next + '</a>' +
                '<div class="' + t.settings.theme + '-contents"></div>' +
                '<div class="' + t.settings.theme + '-caption"><p></p></div>' +
                '</div>').appendTo('body').css('zIndex', t.settings.zIndex).fadeIn(t.settings.speed)
                .on('click.rebox', '.' + t.settings.theme + '-close', function (e) { e.preventDefault(); t.close(); })
                .on('click.rebox', '.' + t.settings.theme + '-next', function (e) { e.preventDefault(); t.next(); })
                .on('click.rebox', '.' + t.settings.theme + '-prev', function (e) { e.preventDefault(); t.prev(); });

            // add some key hooks
            $(document).on('swipeLeft.rebox', function (e) { t.next(); })
                .on('swipeRight.rebox', function (e) { t.prev(); })
                .on('keydown.rebox', function (e) {
                    e.preventDefault();
                    var key = (window.event) ? event.keyCode : e.keyCode;
                    switch (key) {
                        case 27: t.close(); break; // escape key closes
                        case 37: t.prev(); break;  // left arrow to prev
                        case 39: t.next(); break;  // right arrow to next
                    }
                });

            t.$el.trigger('rebox:open', [t]);
            t.goto(i);
            return t.$el;
        },
        close: function () {
            var t = this;

            if (t.$box && t.$box.length) {
                t.$box.fadeOut(t.settings.speed, function (e) {
                    t.$box.remove();
                    t.$box = null;
                    t.$el.trigger('rebox:close', [t]);
                });
            }
            $(document).off('.rebox');

            return t.$el;
        },
        goto: function (i) {
            var t = this,
                $item = $(t.$items[i]),
                captionVal = $item.attr(t.settings.captionAttr),
                $cap = t.$box.children('.' + t.settings.theme + '-caption')[captionVal ? 'show' : 'hide']().children('p').text(captionVal),
                $bi = t.$box.children('.' + t.settings.theme + '-contents'),
                $img = null;

            if ($item.length) {
                t.idx = i;
                $bi.html('<div class="' + t.settings.theme + '-loading ' + t.settings.theme + '-button">' + t.settings.loading + '</div>');

                $img = t.settings.templates[$item.data('rebox-template') || t.settings.template]($item, t.settings, function (content) {
                    $bi.empty().append($(this));
                });

                if (t.$items.length == 1 || !t.settings.cycle) {
                    t.$box.children('.' + t.settings.theme + '-prev')[i <= 0 ? 'hide' : 'show']();
                    t.$box.children('.' + t.settings.theme + '-next')[i >= t.$items.length - 1 ? 'hide' : 'show']();
                }
                t.$el.trigger('rebox:goto', [t, i, $item, $img]);
            }
            return t.$el;
        },
        prev: function () {
            var t = this;
            return t.goto(t.idx === 0 ? t.$items.length - 1 : t.idx - 1);
        },
        next: function () {
            var t = this;
            return t.goto(t.idx === t.$items.length - 1 ? 0 : t.idx + 1);
        },
        disable: function () {
            var t = this;
            return t.close().off('.rebox').trigger('rebox:disable', [t]);
        },
        destroy: function () {
            var t = this;
            return t.disable().removeData('rebox').trigger('rebox:destroy');
        },
        option: function (key, val) {
            var t = this;
            if (val !== undefined) {
                t.settings[key] = val;
                return t.disable().enable();
            }
            return t.settings[key];
        }
    });

    $.fn.rebox = function (o) {
        o = o || {};
        var tmp_args = Array.prototype.slice.call(arguments);

        if (typeof (o) == 'string') {
            if (o == 'option' && typeof (tmp_args[1]) == 'string' && tmp_args.length === 2) {
                var inst = $.rebox.lookup[$(this).data('rebox')];
                return inst[o].apply(inst, tmp_args.slice(1));
            }
            else return this.each(function () {
                var inst = $.rebox.lookup[$(this).data('rebox')];
                inst[o].apply(inst, tmp_args.slice(1));
            });
        } else return this.each(function () {
            var $t = $(this);
            $.rebox.lookup[++$.rebox.lookup.i] = new $.rebox($t, o);
            $t.data('rebox', $.rebox.lookup.i);
        });
    };


})(window.jQuery || window.Zepto || window.$);

Ниже приведен код файла jquery-rebox.css, связанного с плагином.

Язык кода:javascript
копировать
.rebox { 
    cursor: pointer; 
    position: fixed; 
    width: 100%; 
    height: 100%; 
    top: 0; 
    left: 0; 
    z-index: 1000; 
    -webkit-filter: none !important;
    background: rgb(0, 0, 0); 
    background: url();
    background: rgba(0, 0, 0, 0.7); 
}
.rebox *{ 
    -webkit-box-sizing: border-box; 
    -moz-box-sizing: border-box; 
    -ms-box-sizing: border-box; 
    -o-box-sizing: border-box; 
    box-sizing: border-box; 
    padding: 0; 
    margin: 0; 
}
.rebox-contents { 
    position: absolute; 
    top: 5%; 
    left: 5%; 
    text-align: center; 
    width: 90%; 
    height: 90%; 
}
.rebox-contents .rebox-content { 
    border: 5px solid #fff; 
    box-shadow: 0 0 20px #000; 
    border-radius: 1px; 
    max-width: 100%; 
    max-height: 100%; 
}
.rebox-loading { 
    width: 31px; 
    height: 31px; 
    margin: -16px 0 0 -16px; 
    position: absolute; 
    top: 48%; 
    left: 50%; 
}
.rebox-caption { 
    display: none; 
    position: absolute; 
    left: 0; 
    bottom: 0; 
    width: 100%; 
    text-align: center; 
    z-index: 1000; 
    background: #000; 
    background: rgba(0,0,0,0.7); 
}
.rebox-caption p { 
    margin: 0 auto; 
    max-width: 70%; 
    display: inline-block; 
    *display: inline; 
    *zoom: 1; 
    padding: 10px; 
    color: #fff; 
    font-size: 12px; 
    line-height: 18px; 
}

.rebox-button { 
    position: absolute; 
    z-index: 9999; 
    min-width: 40px; 
    height: 40px; 
    line-height: 40px; 
    background: rgb(0, 0, 0); 
    opacity:0.4; 
    text-decoration: none; 
    font-size: 24px; 
    color: #fff; 
    text-align: center; 
    vertical-align: middle;
    -webkit-border-radius: 32px; 
    -moz-border-radius: 32px; 
    -ms-border-radius: 32px; 
    border-radius: 32px;
    -webkit-transition: all 0.3s; 
    -moz-transition: all 0.3s; 
    -ms-transition: all 0.3s; 
    transition: all 0.3s; 
}
.rebox-button:hover,
.rebox-button:focus { 
    opacity: 1; 
    -webkit-transform: scale(1.4); 
    -moz-transform: scale(1.4); 
    -ms-transform: scale(1.4); 
    transform: scale(1.4); 
}
.rebox-close { 
    right: 10px; 
    top: 10px; 
}
.rebox-next { 
    right: 10px; 
    top: 48%; 
}
.rebox-prev { 
    left: 10px; 
    top: 48%; 
}
.rebox-loading { 
    left: 50%; 
    top: 48%;
    -webkit-animation-name: spin; 
    -webkit-animation-duration: 2000ms; 
    -webkit-animation-iteration-count: infinite; 
    -webkit-animation-timing-function: linear;
    -moz-animation-name: spin; 
    -moz-animation-duration: 2000ms; 
    -moz-animation-iteration-count: infinite; 
    -moz-animation-timing-function: linear;
    -ms-animation-name: spin; 
    -ms-animation-duration: 2000ms; 
    -ms-animation-iteration-count: infinite; 
    -ms-animation-timing-function: linear;    
    animation-name: spin; 
    animation-duration: 2000ms; 
    animation-iteration-count: infinite; 
    animation-timing-function: linear;
}

@-ms-keyframes spin {
    from { -ms-transform: rotate(0deg); }
    to { -ms-transform: rotate(360deg); }
}
@-moz-keyframes spin {
    from { -moz-transform: rotate(0deg); }
    to { -moz-transform: rotate(360deg); }
}
@-webkit-keyframes spin {
    from { -webkit-transform: rotate(0deg); }
    to { -webkit-transform: rotate(360deg); }
}
@keyframes spin {
    from { transform:rotate(0deg); }
    to { transform:rotate(360deg); }
}
boy illustration
Неразрушающее увеличение изображений одним щелчком мыши, чтобы сделать их более четкими артефактами искусственного интеллекта, включая руководства по установке и использованию.
boy illustration
Копикодер: этот инструмент отлично работает с Cursor, Bolt и V0! Предоставьте более качественные подсказки для разработки интерфейса (создание навигационного веб-сайта с использованием искусственного интеллекта).
boy illustration
Новый бесплатный RooCline превосходит Cline v3.1? ! Быстрее, умнее и лучше вилка Cline! (Независимое программирование AI, порог 0)
boy illustration
Разработав более 10 проектов с помощью Cursor, я собрал 10 примеров и 60 подсказок.
boy illustration
Я потратил 72 часа на изучение курсорных агентов, и вот неоспоримые факты, которыми я должен поделиться!
boy illustration
Идеальная интеграция Cursor и DeepSeek API
boy illustration
DeepSeek V3 снижает затраты на обучение больших моделей
boy illustration
Артефакт, увеличивающий количество очков: на основе улучшения характеристик препятствия малым целям Yolov8 (SEAM, MultiSEAM).
boy illustration
DeepSeek V3 раскручивался уже три дня. Сегодня я попробовал самопровозглашенную модель «ChatGPT».
boy illustration
Open Devin — инженер-программист искусственного интеллекта с открытым исходным кодом, который меньше программирует и больше создает.
boy illustration
Эксклюзивное оригинальное улучшение YOLOv8: собственная разработка SPPF | SPPF сочетается с воспринимаемой большой сверткой ядра UniRepLK, а свертка с большим ядром + без расширения улучшает восприимчивое поле
boy illustration
Популярное и подробное объяснение DeepSeek-V3: от его появления до преимуществ и сравнения с GPT-4o.
boy illustration
9 основных словесных инструкций по доработке академических работ с помощью ChatGPT, эффективных и практичных, которые стоит собрать
boy illustration
Вызовите deepseek в vscode для реализации программирования с помощью искусственного интеллекта.
boy illustration
Познакомьтесь с принципами сверточных нейронных сетей (CNN) в одной статье (суперподробно)
boy illustration
50,3 тыс. звезд! Immich: автономное решение для резервного копирования фотографий и видео, которое экономит деньги и избавляет от беспокойства.
boy illustration
Cloud Native|Практика: установка Dashbaord для K8s, графика неплохая
boy illustration
Краткий обзор статьи — использование синтетических данных при обучении больших моделей и оптимизации производительности
boy illustration
MiniPerplx: новая поисковая система искусственного интеллекта с открытым исходным кодом, спонсируемая xAI и Vercel.
boy illustration
Конструкция сервиса Synology Drive сочетает проникновение в интрасеть и синхронизацию папок заметок Obsidian в облаке.
boy illustration
Центр конфигурации————Накос
boy illustration
Начинаем с нуля при разработке в облаке Copilot: начать разработку с минимальным использованием кода стало проще
boy illustration
[Серия Docker] Docker создает мультиплатформенные образы: практика архитектуры Arm64
boy illustration
Обновление новых возможностей coze | Я использовал coze для создания апплета помощника по исправлению домашних заданий по математике
boy illustration
Советы по развертыванию Nginx: практическое создание статических веб-сайтов на облачных серверах
boy illustration
Feiniu fnos использует Docker для развертывания личного блокнота Notepad
boy illustration
Сверточная нейронная сеть VGG реализует классификацию изображений Cifar10 — практический опыт Pytorch
boy illustration
Начало работы с EdgeonePages — новым недорогим решением для хостинга веб-сайтов
boy illustration
[Зона легкого облачного игрового сервера] Управление игровыми архивами
boy illustration
Развертывание SpringCloud-проекта на базе Docker и Docker-Compose