CSS - Стили, связанные с вводом формы

RedDeveloper
22.04.2023 07:29
CSS - Стили, связанные с вводом формы

CSS - Стили, связанные с вводом формы

Общими стилями ввода для форм являются Input (включая Text, Radio, checkbox), Select и Textarea, из которых Input относительно прост, поэтому в этой статье мы расскажем о стилях, связанных с Select и Textarea.

Стиль Select

Основной стиль:

<select>
  <option value = "0">Select car</option>
  <option value = "1">Audi</option>
  <option value = "2">BMW</option>
  <option value = "3">Citroen</option>
  <option value = "4">Ford</option>
  <option value = "5">Honda</option>
  <option value = "6">Jaguar</option>
  <option value = "7">Land Rover</option>
  <option value = "8">Mercedes</option>
  <option value = "9">Mini</option>
  <option value = "10">Nissan</option>
  <option value = "11">Toyota</option>
  <option value = "12">Volvo</option>
</select>

Оригинальный основной стиль:

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

Мы обернули исходный HTML Select пользовательским классом Select и обработали внутренний Select через этот класс (чтобы облегчить последующее повторное использование):

<div class = "custom-select" style = "width:200px;">
  <select>
    <option value = "0">Select car</option>
    <option value = "1">Audi</option>
    <option value = "2">BMW</option>
    <option value = "3">Citroen</option>
    <option value = "4">Ford</option>
    <option value = "5">Honda</option>
    <option value = "6">Jaguar</option>
    <option value = "7">Land Rover</option>
    <option value = "8">Mercedes</option>
    <option value = "9">Mini</option>
    <option value = "10">Nissan</option>
    <option value = "11">Toyota</option>
    <option value = "12">Volvo</option>
  </select>
</div>

Добавить JavaScript:

var x, i, j, l, ll, selElmnt, a, b, c;
// 1. 抓取當前頁面所有需要客製化樣式的 Select
x = document.getElementsByClassName("custom-select");
l = x.length;
for (i = 0; i < l; i++) {
  selElmnt = x[i].getElementsByTagName("select")[0];
  ll = selElmnt.length;

  // 2. 創建一個已選擇的 UI Select 介面
  a = document.createElement("DIV");
  a.setAttribute("class", "select-selected");
  a.innerHTML = selElmnt.options[selElmnt.selectedIndex].innerHTML;
  x[i].appendChild(a);

  // 3. 將原本的 Select 隱藏
  b = document.createElement("DIV");
  b.setAttribute("class", "select-items select-hide");

  // 4. 將 Select 的選項添加到 UI Select 介面
  for (j = 1; j < ll; j++) {
    c = document.createElement("DIV");
    c.innerHTML = selElmnt.options[j].innerHTML;
    
    // 5. 替添加的 UI Select 介面選項設定點擊事件
    c.addEventListener("click", function(e) {
        var y, i, k, s, h, sl, yl;
        s = this.parentNode.parentNode.getElementsByTagName("select")[0];
        sl = s.length;
        h = this.parentNode.previousSibling;
        for (i = 0; i < sl; i++) {
          if (s.options[i].innerHTML == this.innerHTML) {
            s.selectedIndex = i;
            h.innerHTML = this.innerHTML;
            y = this.parentNode.getElementsByClassName("same-as-selected");
            yl = y.length;
            for (k = 0; k < yl; k++) {
              y[k].removeAttribute("class");
            }
            this.setAttribute("class", "same-as-selected");
            break;
          }
        }
        h.click();
    });
    b.appendChild(c);
  }
  x[i].appendChild(b);

  // 6. 點擊選項後將 UI Select 介面選項收合
  a.addEventListener("click", function(e) {
      e.stopPropagation();
      closeAllSelect(this);
      this.nextSibling.classList.toggle("select-hide");
      this.classList.toggle("select-arrow-active");
    });
}

// 介面選項收合函式
function closeAllSelect(elmnt) {
  var x, y, i, xl, yl, arrNo = [];
  x = document.getElementsByClassName("select-items");
  y = document.getElementsByClassName("select-selected");
  xl = x.length;
  yl = y.length;
  for (i = 0; i < yl; i++) {
    if (elmnt == y[i]) {
      arrNo.push(i)
    } else {
      y[i].classList.remove("select-arrow-active");
    }
  }
  for (i = 0; i < xl; i++) {
    if (arrNo.indexOf(i)) {
      x[i].classList.add("select-hide");
    }
  }
}

// 7. 點擊其他地方後將 UI Select 介面選項收合
document.addEventListener("click", closeAllSelect);

Стили:

/*the container must be positioned relative:*/
.custom-select {
  position: relative;
  font-family: Arial;
}

.custom-select select {
  display: none; /*hide original SELECT element:*/
}

.select-selected {
  background-color: DodgerBlue;
}

/*style the arrow inside the select element:*/
.select-selected:after {
  position: absolute;
  content: "";
  top: 14px;
  right: 10px;
  width: 0;
  height: 0;
  border: 6px solid transparent;
  border-color: #fff transparent transparent transparent;
}

/*point the arrow upwards when the select box is open (active):*/
.select-selected.select-arrow-active:after {
  border-color: transparent transparent #fff transparent;
  top: 7px;
}

/*style the items (options), including the selected item:*/
.select-items div,.select-selected {
  color: #ffffff;
  padding: 8px 16px;
  border: 1px solid transparent;
  border-color: transparent transparent rgba(0, 0, 0, 0.1) transparent;
  cursor: pointer;
  user-select: none;
}

/*style items (options):*/
.select-items {
  position: absolute;
  background-color: DodgerBlue;
  top: 100%;
  left: 0;
  right: 0;
  z-index: 99;
}

/*hide the items when the select box is closed:*/
.select-hide {
  display: none;
}

.select-items div:hover, .same-as-selected {
  background-color: rgba(0, 0, 0, 0.1);
}

Настроенный стиль:

Настроенный стиль

Это сложно? Неважно, на самом деле вы можете использовать это приложение в несколько шагов:

  1. Добавьте внешний слой Select <div class = "custom-select">к оригинальному Select</div&gt.
  2. Скопируйте и вставьте JavaScript и CSS
  3. Измените CSS в соответствии с вашими потребностями

Стиль Textarea

Стиль Textarea можно изменить, просто настроив цвет шрифта, цвет фона и цвет границы с помощью параметров color, background-colour и border-colour соответственно.

Размер может быть изменен путем изменения размера

  • resize: both; -> Можно изменить как длину, так и ширину.
  • resize: vertical; -> Можно изменить только вертикальную длину
  • resize: horizontal; -> можно изменить только ширину по горизонтали

Конечно, вы также можете использовать overflow: auto; и ::-webkit-scrollbar для полосы прокрутки.

Это все на сегодня. С этим вы можете иметь больше свободы в стиле ввода формы!

Почему в Python есть оператор &quot;pass&quot;?
Почему в Python есть оператор "pass"?

05.05.2023 14:00

Оператор pass в Python - это простая концепция, которую могут быстро освоить даже новички без опыта программирования.

Коллекции в Laravel более простым способом
Коллекции в Laravel более простым способом

05.05.2023 11:59

Привет, читатели, сегодня мы узнаем о коллекциях. В Laravel коллекции - это способ манипулировать массивами и играть с массивами данных. Благодаря своим методам, они делают код очень простым для понимания и читабельным.

JavaScript Вопросы с множественным выбором и ответы
JavaScript Вопросы с множественным выбором и ответы

05.05.2023 11:57

Если вы ищете платформу, которая предоставляет вам бесплатный тест JavaScript MCQ (Multiple Choice Questions With Answers) для оценки ваших знаний, то, не теряя времени, практикуйте наш бесплатный онлайн тест 1100+ JavaScript MCQs и развивайте свои навыки и знания.

Массив зависимостей в React
Массив зависимостей в React

05.05.2023 09:44

Все о массиве Dependency и его связи с useEffect.