【问题标题】:How to customize Input slider to make volume bar如何自定义输入滑块以制作音量条
【发布时间】:2020-12-07 16:28:41
【问题描述】:

我正在尝试使用带有样式组件的输入滑块制作音量条。

我可以找到许多有用的信息,但找不到有关如何自定义有价值区域的信息。 例如,如果我将音量设置为 80,则默认 html 输入范围颜色从 0 到 80 蓝色。我想更改此颜色,但找不到任何有关它的信息。当我设置-webkit-appearance: none; 时,我发现它变得透明了,但我只想改变它的颜色。 (不是背景。我知道我可以用背景做到这一点)。

编辑)这是我的代码

const StyledTrackVolumeSlide = styled.input`
  width: 100%;
  // -webkit-appearance: none; I know this code will reset default css
  background: #555;
  height: 0.25em;
  outline: none;
  &::-webkit-slider-thumb {
    -webkit-appearance: none;
  }

我尝试了这些属性,但找不到具有蓝色值背景颜色的属性。而且在 chrome 开发工具中也找不到。尝试了here的所有东西

&::-webkit-slider-thumb{
}

&:focus{

}

&::-ms-track{

}

有没有办法用纯 CSS 自定义输入滑块的值颜色?

【问题讨论】:

  • 到目前为止你尝试过什么?在这里也发布您的代码
  • @PrathameshKosht​​i 我编辑了!

标签: javascript css input range


【解决方案1】:

查看此工具:https://toughengineer.github.io/demo/slider-styler

除其他外,它还允许设置进度指示样式。

不过,要使滑块垂直,您必须使用 CSS 变换。

这是一个例子:

for (let e of document.querySelectorAll('input[type="range"].slider-progress')) {
  e.style.setProperty('--value', e.value);
  e.style.setProperty('--min', e.min == '' ? '0' : e.min);
  e.style.setProperty('--max', e.max == '' ? '100' : e.max);
  e.addEventListener('input', () => e.style.setProperty('--value', e.value));
}
/*generated with Input range slider CSS style generator (version 20201223)
https://toughengineer.github.io/demo/slider-styler*/
input[type=range].styled-slider {
  height: 2.2em;
  -webkit-appearance: none;
}

/*progress support*/
input[type=range].styled-slider.slider-progress {
  --range: calc(var(--max) - var(--min));
  --ratio: calc((var(--value) - var(--min)) / var(--range));
  --sx: calc(0.5 * 2em + var(--ratio) * (100% - 2em));
}

input[type=range].styled-slider:focus {
  outline: none;
}

/*webkit*/
input[type=range].styled-slider::-webkit-slider-thumb {
  width: 2em;
  height: 2em;
  border-radius: 1em;
  background: #007cf8;
  border: none;
  box-shadow: 0 0 2px black;
  margin-top: calc(max((1em - 1px - 1px) * 0.5,0px) - 2em * 0.5);
  -webkit-appearance: none;
}

input[type=range].styled-slider::-webkit-slider-runnable-track {
  height: 1em;
  border-radius: 0.5em;
  background: #efefef;
  border: 1px solid #b2b2b2;
  box-shadow: none;
}
input[type=range].styled-slider::-webkit-slider-thumb:hover {
  background: #0061c3;
}

input[type=range].styled-slider:hover::-webkit-slider-runnable-track {
  background: #e5e5e5;
  border-color: #9a9a9a;
}

input[type=range].styled-slider::-webkit-slider-thumb:active {
  background: #2f98f9;
}

input[type=range].styled-slider:active::-webkit-slider-runnable-track {
  background: #f5f5f5;
  border-color: #c1c1c1;
}

input[type=range].styled-slider.slider-progress::-webkit-slider-runnable-track {
  background: linear-gradient(#007cf8,#007cf8) 0/var(--sx) 100% no-repeat, #efefef;
}

input[type=range].styled-slider.slider-progress:hover::-webkit-slider-runnable-track {
  background: linear-gradient(#0061c3,#0061c3) 0/var(--sx) 100% no-repeat, #e5e5e5;
}

input[type=range].styled-slider.slider-progress:active::-webkit-slider-runnable-track {
  background: linear-gradient(#2f98f9,#2f98f9) 0/var(--sx) 100% no-repeat, #f5f5f5;
}

/*mozilla*/
input[type=range].styled-slider::-moz-range-thumb {
  width: 2em;
  height: 2em;
  border-radius: 1em;
  background: #007cf8;
  border: none;
  box-shadow: 0 0 2px black;
}

input[type=range].styled-slider::-moz-range-track {
  height: max(calc(1em - 1px - 1px),0px);
  border-radius: 0.5em;
  background: #efefef;
  border: 1px solid #b2b2b2;
  box-shadow: none;
}

input[type=range].styled-slider::-moz-range-thumb:hover {
  background: #0061c3;
}

input[type=range].styled-slider:hover::-moz-range-track {
  background: #e5e5e5;
  border-color: #9a9a9a;
}

input[type=range].styled-slider::-moz-range-thumb:active {
  background: #2f98f9;
}

input[type=range].styled-slider:active::-moz-range-track {
  background: #f5f5f5;
  border-color: #c1c1c1;
}

input[type=range].styled-slider.slider-progress::-moz-range-track {
  background: linear-gradient(#007cf8,#007cf8) 0/var(--sx) 100% no-repeat, #efefef;
}

input[type=range].styled-slider.slider-progress:hover::-moz-range-track {
  background: linear-gradient(#0061c3,#0061c3) 0/var(--sx) 100% no-repeat, #e5e5e5;
}

input[type=range].styled-slider.slider-progress:active::-moz-range-track {
  background: linear-gradient(#2f98f9,#2f98f9) 0/var(--sx) 100% no-repeat, #f5f5f5;
}

/*ms*/
input[type=range].styled-slider::-ms-fill-upper {
  background: transparent;
  border-color: transparent;
}

input[type=range].styled-slider::-ms-fill-lower {
  background: transparent;
  border-color: transparent;
}

input[type=range].styled-slider::-ms-thumb {
  width: 2em;
  height: 2em;
  border-radius: 1em;
  background: #007cf8;
  border: none;
  box-shadow: 0 0 2px black;
  margin-top: 0;
  box-sizing: border-box;
}

input[type=range].styled-slider::-ms-track {
  height: 1em;
  border-radius: 0.5em;
  background: #efefef;
  border: 1px solid #b2b2b2;
  box-shadow: none;
  box-sizing: border-box;
}

input[type=range].styled-slider::-ms-thumb:hover {
  background: #0061c3;
}

input[type=range].styled-slider:hover::-ms-track {
  background: #e5e5e5;
  border-color: #9a9a9a;
}

input[type=range].styled-slider::-ms-thumb:active {
  background: #2f98f9;
}

input[type=range].styled-slider:active::-ms-track {
  background: #f5f5f5;
  border-color: #c1c1c1;
}

input[type=range].styled-slider.slider-progress::-ms-fill-lower {
  height: max(calc(1em - 1px - 1px),0px);
  border-radius: 0.5em 0 0 0.5em;
  margin: -1px 0 -1px -1px;
  background: #007cf8;
  border: 1px solid #b2b2b2;
  border-right-width: 0;
}

input[type=range].styled-slider.slider-progress:hover::-ms-fill-lower {
  background: #0061c3;
  border-color: #9a9a9a;
}

input[type=range].styled-slider.slider-progress:active::-ms-fill-lower {
  background: #2f98f9;
  border-color: #c1c1c1;
}
<input type="range" class="styled-slider slider-progress" style="width: 25em;" />
<br />

<!--this div is needed to cut off all that's not needed, you have to specify width explicitly-->
<div style="display: inline-block; width: 2.2em; overflow: hidden;">
  <!--this div catches the size of the child block-->
  <div style="display: inline-block;">
    <!--this div sizes itself to the width of the <input> and makes itself square, also rotates contents-->
    <div style="display: inline-block; height: 0; padding: 0 0 100% 0; transform: rotate(-90deg);">
      <!--style <input> as usual as if it is horizontal-->
      <input type="range" class="styled-slider slider-progress" style="width: 10em;" />
    </div>
  </div>
</div>
more content to the right of the vertical slider

【讨论】:

  • 这正是我所需要的。我认为这是我能找到的最友好的范围 CSS 代码生成器。谢谢! @保罗
  • @YuTaek,很高兴你喜欢它。 ?
【解决方案2】:

“默认 html 输入范围颜色”不存在,该元素由您的浏览器呈现。

您必须指定-webkit-appearance: none;(取决于浏览器),以告诉浏览器“不要设计输入,我会处理”。
another tutorial

遗憾的是你必须重新创建输入元素,你不能只覆盖颜色。

【讨论】:

  • 谢谢,那我现在知道该怎么做了。很难找到它:/再次感谢!
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 2022-11-21
  • 1970-01-01
  • 2017-02-16
  • 2013-11-10
  • 1970-01-01
  • 1970-01-01
  • 2013-05-18
相关资源
最近更新 更多