CSS простой горизонтальный слайдер

Пример подойдёт в случае если нужно сделать простой горизонтальный слайдер без подключения сторонних библиотек. Приведенный код можно взять за основу и доработать под требования конкретной задачи например добавить кнопки навигации, увеличение изображения при клике на слайд и т.д.

<div class="slider-items">
<div class="slider-item"></div>
<div class="slider-item">
<p>Lorem ipsum dolor sit amet, 
consectetur adipiscing elit,
sed do eiusmod tempor incididunt ut
labore et dolore magna aliqua.
Ut enim ad minim veniam, quis
nostrud exercitation ullamco laboris
nisi ut aliquip ex ea commodo consequat.</p> </div> <div class="slider-item"></div> <div class="slider-item"></div> <div class="slider-item"></div> </div>
.slider-items {
    width: 100%;
    background-color: gray;
    display: flex;
    flex-direction: row;
    gap: 10px;
    padding: 10px 10px;
    overflow-x: scroll;
    cursor: pointer;
    user-select: none;
    scrollbar-width: none;
}
.slider-items::-webkit-scrollbar {
    display: none;
}
.slider-item {
    width: 220px;
    min-width: 220px;
    height: 180px;
    background-color: black;
    padding: 10px;
    overflow: hidden;
    color: #fff;
}
.slider-item:first-child {
    background-image: url('/files/img/article/css_gorizontalnaya_prokrutka/slide1.png');
    background-size: contain;
}
.slider-item:nth-child(3) {
    background-color: #5820f6;
}
.slider-item:nth-child(4) {
    background-color: #32cb5d;
}
.slider-item:nth-child(5) {
    background-color: #a56ffd;
}
document.addEventListener('DOMContentLoaded', function() {
	initCustomSlider();
});

function initCustomSlider() {
	const slider = document.querySelector('.slider-items');
	let isDown = false;
	let startX;
	let scrollLeft;

	slider.addEventListener('mousedown', (e) => {
		isDown = true;
		slider.classList.add('active');
		startX = e.pageX - slider.offsetLeft;
		scrollLeft = slider.scrollLeft;
	});
	slider.addEventListener('mouseleave', () => {
		isDown = false;
		slider.classList.remove('active');
	});
	slider.addEventListener('mouseup', () => {
		isDown = false;
		slider.classList.remove('active');
	});
	slider.addEventListener('mousemove', (e) => {
		if (!isDown)
			return;
		e.preventDefault();
		e.stopPropagation();
		const x = e.pageX - slider.offsetLeft;
		const walk = (x - startX) * 2; //Ускорение, чтобы слайдер быстрее пролистывался
		slider.scrollLeft = scrollLeft - walk;
	});
}

Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat.

Еще одним преимуществом данного слайдера является то, что он может показывать не целое число слайдов, например: 2,5 слайда, 3,3 слайда и т.д. Таким образом пользователь сразу видит, что есть еще какая-то информация и можно передвинуть слайдер, чтобы с ней ознакомится.

Так же работу слайдера можно посмотреть на отдельной странице.

Рубрики: CSS

Если есть вопросы, что-то в статье не понятно или нашли ошибку, напишите об этом в комментариях, все комментарии читаются и по возможности материал будет доработан.
Популярные статьи

Ncdu: Идеальный инструмент для анализа дискового пространства

ncdu — удобный инструмент для анализа и управления дисковым пространством. Узнайте, как установить и использовать ncdu, основные команды и преимущества по сравнению с классическим du.

Что нового в PHP 8.3?

Обзор новых возможностей PHP 8.3.

Использование chatGpt в работе: генерация html

В этой статье мы рассмотрим пару примером генерации html кода с помощью нейросетей, что позволяет ускорить процесс разработки.

PHP вывод использованного места по каталогам

С помощью программы ncdu и ей подобных можно легко проанализировать объем занятого дискового пространства, но не всегда удобно подключаться к серверу, писать необходимые комманды, поэтому я решил написать для себя web вариант подобной программы.

Yii2 как получить путь к корню проекта

Узнайте, как правильно получить путь к корню проекта в Yii2 с помощью встроенных инструментов фреймворка.

Как в Битрикс 24 открыть страницу в слайдере

В статье приводится пример кода с описанием параметров для открытия страницы в слайдере.

Комментарии

Юрий [10.03.2024]
Здравствуйте. Скрипт не срабатывает. Не хотят имиджи меняться как у Вас на примере.
Вот здесь https://test.getalit.by/
Admin [25.03.2024]
Добрый день.
Проверили код, всё работает, сделали отдельную страницу с примером https://precord.ru/files/slider.html где кроме слайдера ничего нет.
Возможно у вас возникают конфликты с другими скриптами или библиотеками на странице.
По ссылки не нашли подходящего слайдера, чтобы проверить в чем может быть проблема.
Юра [07.05.2024]
Ну как же без сторонних библиотек? jquery-2.2.4.min.js?
Admin [23.05.2024]
Юрий, спасибо за ценное замечание!
Доработали код так, чтобы jquery так же не требовался для работы.
Хотя заметим, что jquery сложно назвать сторонней библиотекой из-за своего широкого распространения, наличия на большинстве сайтов и входящей в состав различных фреймворков.
Марк [22.08.2024]
Спасибо за это прекрасное решение. Это то, что мне нужно было! Процветания вашему сайту :)
Марк [23.08.2024]
Понравилась ваша функция "Поделиться" на этой странице. Скажите, есть ли у вас статья про то, как реализовать такую функцию пересылки в Телеграм, ВКонтакте и Ватсап на сайте?
Admin [26.08.2024]
Марк, добрый день. Спасибо за обратную связь :)
Для блока "Поделится" используется библиотека от яндекса. У них в инструкции все довольно подробно описано: https://yandex.ru/dev/dev/share/doc/dg/add.html
Данный сайт использует файлы cookies. Продолжая просмотр сайта, вы соглашаетесь с использованием файлов cookies.
ОК