Михаил Базаров Разработка на 1С-Битрикс Михаил Базаров

Кастомизация поля input type file, свой внешний вид

Просмотров: 3786 Задача: Поле input type="file" предоставляет возможность загрузки файлов на веб-странице. Однако стандартный вид этого элемента не всегда соответствует дизайну сайта. В данной статье мы рассмотрим методы кастомизации этого поля с использованием CSS и JavaScript.
Кастомизация поля input type file

Кастомизация с помощью CSS и JavaScript

Для изменения внешнего вида и поведения поля input type="file" мы воспользуемся следующими шагами:

Скрытие стандартного элемента и создание кастомного интерфейса:
Мы скроем стандартный элемент input type="file" с помощью CSS и создадим собственный интерфейс, используя контейнер и метку (label). Контейнер будет содержать текст и метку, которая будет выглядеть как кнопка для выбора файла.

<div class="custom-file-upload">
     <span>Файл для аватарки</span>
     <label for="file" id="file-label">
          Прикрепить фото
     </label>
     <input type="file" id="file" class="hidden" name="PREVIEW_PICTURE" maxlength="25" autocomplete="off" value="">
</div>

Стилизация элементов с использованием CSS:
Мы применяем стили к созданным элементам, чтобы они выглядели и вели себя так, как нам нужно.

.custom-file-upload {
    display: inline-block;
    position: relative;
}

.custom-file-upload label {
    height: 60px;
    background: var(--c_blue_light_bg);
    outline: 0;
    border: 0;
    width: 100%;
    border-radius: var(--radius10);
    font-family: inherit;
    cursor: pointer;
}

.custom-file-upload input {
    display: none;
}

В данном примере, мы устанавливаем определенные стили для контейнера и метки, чтобы они выглядели как кнопка. Также мы скрываем стандартный input с помощью display: none;.

Добавление обработчика события при выборе файла:
Мы используем JavaScript, чтобы добавить обработчик события, который будет вызван при выборе файла пользователем. Этот обработчик обновит текст метки с названием выбранного файла.

document.getElementById('file').addEventListener('change', function() {
    var filename = this.files[0].name;
    document.getElementById('file-label').innerText = filename;
});

Этот скрипт получает элемент с id file, добавляет к нему слушатель события change, и при изменении вызывает функцию, которая обновляет текст метки с названием файла. Сам label можно как угодно кастомизировать, с помощью css, под дизайн вашего сайта

Услуги Стоимость разработки на 1С-Битрикс

Стоимость разработки сайта зависит от объёма и сложности проекта. Ниже приведены ориентировочные цены, как правило не выходят за обозначенные рамки. Срок разработки зависит от сложности проекта: как правило называю сроки с запасом.
Финальная стоимость и сроки разработки обговариваются на этапе обсуждения. Скачайте опросник на разработку, заполните как можно подробнее и вышлите удобным способом. После ознакомления смогу задать уточняющие вопросы и оценить проект.
Индивидуальная разработка магазина
от 300 000 руб. от 5-ти недель

Разработка магазина на 1С-Битрикс с нуля. Дизайн, сборка и оптимизация производительности под конкретный проект и требования. Реализация любого функционала без ограничений готовых решений.

Подробнее
Сайт на готовом решении 1С-Битрикс
от 70 000 руб. от 5-ти дней

Вариант для тех, кто не хочет тратить много средств на индивидуальный проект, и не имеет серьезных требований к сайту. Магазин, быстро запускается на базе одного из 200-та готовых решений.

Подробнее
Мобильное приложение
от 300 000 руб. от 4-х недель

Разработка кроссплатформенного мобильного приложения, которое не уступает нативным решениям как в производительности, так и пользовательском опыте. Публикуется в AppStore, GooglePlay и RuStore

Подробнее
Сайт компании
от 150 000 руб. от 2-х недель

Корпоративный сайт с информационными разделами, каталогом товаров или услуг. Включает формы обратной связи карточек каталога, любое количество статичных и динамичных разделов.

Подробнее
Инфоресурс
от 170 000 руб. от 3-х недель

Информационный ресурс любой сложности. Сайт для СМИ, городской портал или многопользовательская доска объявлений. Внутренние форумы, блоги- по необходимости.

Подробнее
Поддержка и доработки проектов
от 3 000 руб. от 1 часа

Выполнение доработок любой сложности. Поддержка, модернизация и расширение функционала существующих проектов. Решение задач: от мелких правок вёрстки до разработки новых модулей.

Подробнее

Включено в стоимость разработки:

  • Лицензия на 1С-Битрикс необходимой редакции, дополнительные модули, для реализации функционала и видео-инструкции по работе с готовым проектом
  • Оптимизация программной части проекта и конфигурации сервера под максимальную скорость работы. Базовая СЕО оптимизация и добавление сайта в поисковые системы.

Блог-note Заметки по 1С-Битрикс