如何创建:范围滑块

学习如何使用 CSS 和 JavaScript 创建自定义范围滑块。

默认:

方块:

圆点:

图像:

值:

亲自试一试

创建范围滑块

第一步 - 添加 HTML:

<div class="slidecontainer">
  <input type="range" min="1" max="100" value="50" class="slider" id="myRange">
</div>

第二步 - 添加 CSS:

.slidecontainer {
  width: 100%; /* 外部容器的宽度 */
}
/* The slider itself */
.slider {
  -webkit-appearance: none;  /* 覆盖默认 CSS 样式 */
  appearance: none;
  width: 100%; /* 全宽 */
  height: 25px; /* 指定的高度 */
  background: #d3d3d3; /* 灰色背景 */
  outline: none; /* 移除轮廓 */
  opacity: 0.7; /* 设置透明度(用于鼠标悬停时的鼠标悬停效果) */
  -webkit-transition: .2s; /* 0.2秒的过渡效果 */
  transition: opacity .2s;
}
/* 鼠标悬停效果 */
.slider:hover {
  opacity: 1; /* 鼠标悬停时完全显示 */
}
/* 滑块手柄(使用 -webkit-(Chrome、Opera、Safari、Edge)和 -moz-(Firefox)来覆盖默认外观) */
.slider::-webkit-slider-thumb {
  -webkit-appearance: none; /* 覆盖默认外观 */
  appearance: none;
  width: 25px; /* ການກວດຄວາມສະເພາະຂອງຄວາມສະເພາະ */
  height: 25px; /* ຄວາມສະເພາະຂອງຄວາມສະເພາະ */
  background: #04AA6D; /* ສີຂຽວ */
  cursor: pointer; /* ຄຳຫຼິ້ນສະໝອງທີ່ສະເພາະ */
}
.slider::-moz-range-thumb {
  width: 25px; /* ການກວດຄວາມສະເພາະຂອງຄວາມສະເພາະ */
  height: 25px; /* ຄວາມສະເພາະຂອງຄວາມສະເພາະ */
  background: #04AA6D; /* ສີຂຽວ */
  cursor: pointer; /* ຄຳຫຼິ້ນສະໝອງທີ່ສະເພາະ */
}

亲自试一试

ບາງການທີສາມ - ສ້າງ JavaScript:

ສ້າງຄຳຫຼິ້ນຂະຫຍາຍຄວາມສະເພາະທີ່ສະແດງຄວາມສະເພາະທີ່ປະຈຸບັນ ທີ່ສະໜັບສະໜູນ JavaScript:

var slider = document.getElementById("myRange");
var output = document.getElementById("demo");
output.innerHTML = slider.value; // ສະແດງຄວາມສະເພາະຄຳຫຼິ້ນສະເພາະ
// ປັບປຸງຄວາມສະເພາະຄຳຫຼິ້ນ (ໃນເວລາທີ່ຫຼິ້ນຄຳຫຼິ້ນຄວາມສະເພາະຂອງຄຳຫຼິ້ນ)
slider.oninput = function() {
  output.innerHTML = this.value;
}

亲自试一试

ຄວາມສະເພາະທີ່ສົງຄາຍ

ເພື່ອສ້າງຄວາມສະເພາະທີ່ສົງຄາຍ, ໃຊ້: border-radius ປະກອບເປັນປະສົມປະສານ.

ຄຳແນະນຳ:ຖ້າເຈົ້າຕ້ອງການມີຄວາມສະເພາະທີ່ບໍ່ມີຄວາມສະເພາະທີ່ອັນຕະລາງ (ໃນບັນຊີນີ້ແມ່ນ 15 ພັນຕາ ແລະ 25 ພັນຕາ), ເພື່ອສ້າງຄວາມສະເພາະຂອງຄຳຫຼິ້ນກັບຄວາມສະເພາະຂອງຄຳຫຼິ້ນທີ່ຫຼາຍກວ່າ:

ຄວາມສະເພາະ

.slider {
  -webkit-appearance: none;
  width: 100%;
  height: 15px;
  border-radius: 5px;  
  background: #d3d3d3;
  outline: none;
  opacity: 0.7;
  -webkit-transition: .2s;
  transition: opacity .2s;
}
.slider::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: 25px;
  height: 25px;
  border-radius: 50%; 
  background: #04AA6D;
  cursor: pointer;
}
.slider::-moz-range-thumb {
  width: 25px;
  height: 25px;
  border-radius: 50%;
  background: #04AA6D;
  cursor: pointer;
}

亲自试一试

ພາບຄວາມສະເພາະ/ຮູບພາບ

ເພື່ອສ້າງຄວາມສະເພາະທີ່ມີພາບ/ຮູບພາບປະກອບໄດ້ໃຊ້: background ຂັ້ນຕອນຂອງປະກອບເປັນຮູບພາບ URL:

ຄວາມສະເພາະ

.slider::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: 23px;
  height: 24px;
  border: 0;
  background: url('contrasticon.png');
  cursor: pointer;
}
.slider::-moz-range-thumb {
  width: 23px;
  height: 25px;
  border: 0;
  background: url('contrasticon.png');
  cursor: pointer;
}

亲自试一试