如何将数据-attr值用于线性渐变背景

Ton*_*bet 7 html css gradient background custom-data-attribute

给出这个输入

.prettyRange {
  -webkit-appereance: none;
}

.prettyRange::-webkit-slider-runnable-track {
  background: -webkit-linear-gradient(right, #fff 0%, green 50%, #fff 0%);
}
Run Code Online (Sandbox Code Playgroud)
<input class="prettyRange" type="range" name="capability" data-percent="100%">
Run Code Online (Sandbox Code Playgroud)

但如果我试图通过attr(数据百分比)设置%,它就不起作用.

background: -webkit-linear-gradient(right, #fff 0%, green attr(data-percent), #fff 0%)
Run Code Online (Sandbox Code Playgroud)

如何使用项目的data-percent属性?

PS:我想使用data-property,因为我需要使用JS更新这个值,我们不能用JS选择伪元素.

Tem*_*fif 4

另一种方法是使用CSS 变量,您可以使用 JS 轻松调整它:

.prettyRange {
  -webkit-appereance: none;
}

.prettyRange::-webkit-slider-runnable-track {
  background: -webkit-linear-gradient(right,#fff 0%,green var(--p,50%), #fff 0%);
}
Run Code Online (Sandbox Code Playgroud)
<input class="prettyRange" type="range" name="capability" style="--p:80%">
<br>
<input class="prettyRange" type="range" name="capability" style="--p:100%">
<br>
<input class="prettyRange" type="range" name="capability" >
Run Code Online (Sandbox Code Playgroud)

使用JS改变值:

document.querySelector('.prettyRange').addEventListener('input',function(e) {
  e.target.style.setProperty('--p', e.target.value*10+'%');
})
Run Code Online (Sandbox Code Playgroud)
.prettyRange {
  -webkit-appereance: none;
}

.prettyRange::-webkit-slider-runnable-track {
  background: -webkit-linear-gradient(right, #fff 0%, green var(--p, 50%), #fff 0%);
}
Run Code Online (Sandbox Code Playgroud)
<input class="prettyRange" min='1' max='10' type="range" name="capability">
Run Code Online (Sandbox Code Playgroud)