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

Просмотров: 1005

Задача: Поле 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, под дизайн вашего сайта

Перетащите файлы
Ничего не найдено
Нажимая кнопку "Отправить" вы соглашаетесь
с политикой конфиденциальности и обработки персональных данных.

Блог-note: заметки разработчика

Удалить половину элементов инфоблока с помощью API

Задача: вот такая странная задача, нужно удалить из инфоблока половину элементов. Не важно каких, просто половину элемен...

Объединить отдельные поля ФИО в одно свойство при оформлении заказа.

Пользователь, при оформлении заказа, заполняет три отдельных поля с фамилией, именем и отчеством. Нам нужно сохранить эт...

Вывод элементов с помощью API битрикс

Иногда, выводить элементы инфоблока с помощью компонентов, может оказаться избыточным. Например, если нужно вывести элем...

Отключить поиск по описаниям товаров в Битрикс

Иногда, нужно отключить поиск по описаниям анонсов и детальному описанию товаров, при разработке сайтов на Битрикс. Сдел...

Вывести имя пользователя добавившего элемент инфоблока в Битрикс

Иногда, необходимо вывести имя пользователя добавившего элемент инфоблока. Например, автора новости или автора объявлени...

Прятать или показывать описание раздела каталога

В новых компонентах и шаблонах catalog.section есть не документированный и не выводимый параметр: "Скрывать описание раз...

Рассылка новинок каталога в автоматическом режиме

Что бы реализовать рассылку новинок каталога на email-ы пользователей, можно воспользоваться событием OnBeforeIBlockElem...

Сниппеты типографики bootstrap, для Битрикс

Если вы подключили bootstrap к своему сайту, или сверстали весь шаблон, подключив bootstrap из ядра битрикс. Имеет смысл...

Автоматическое создание подразделов в инфоблоке при добавлении раздела: реализация события OnAfterIBlockSectionAdd

Задача: когда контент-менеджер создает раздел в инфоблоке, необходимо автоматически создавать подразделы с заранее задан...