<div class="row">
<div class="primary">
<div class="item item-1"></div>
<div class="item item-2"></div>
<div class="item item-3"></div>
<div class="item item-4"></div>
<div class="item item-5"></div>
<div class="item item-6"></div>
<div class="item item-7"></div>
<div class="item item-8"></div>
<div class="item item-9"></div>
<div class="item item-10"></div>
</div>
</div>
<div class="row">
<p class="slider">
<label for="shade">Измените цвет</label>
<input type="range" name="" id="shade" min="0" max="360">
</p>
</div>
:root {
--primary-h: 97;
--primary-l: 41%;
--brand-primary: hsl(var(--primary-h), 50%, var(--primary-l));
--brand-primary-darker: hsl(var(--primary-h), 50%, 36%);
--black-h: 0;
--black-s: 0%;
--black-l: 0%;
}
.primary {
display: flex;
margin-top: 20px;
.item {
flex: 1 1 50px;
height: 60px;
background-color: hsl(var(--primary-h), 50%, var(--primary-l));
}
.item-1 {
--primary-l: 15%;
}
.item-2 {
--primary-l: 20%;
}
.item-3 {
--primary-l: 25%;
}
.item-4 {
--primary-l: 30%;
}
.item-5 {
--primary-l: 35%;
}
.item-6 {
--primary-l: 40%;
}
.item-7 {
--primary-l: 45%;
}
.item-8 {
--primary-l: 50%;
}
.item-9 {
--primary-l: 55%;
}
.item-10 {
--primary-l: 60%;
}
}
body {
padding: 1rem;
font-family: "Roboto";
font-smoothing: antialiased;
osx-font-smoothing: grayscale;
}
.row {
margin-bottom: 2rem;
}
.slider {
max-width: 500px;
margin: 1rem auto;
label {
display: block;
margin-bottom: 0.5rem;
}
input {
width: 100%;
}
}
View Compiled
let slider = document.querySelector('#shade');
slider.value = 97;
slider.addEventListener('input', function(){
console.log(this.value);
document.documentElement.style.setProperty('--primary-h', this.value)
});
This Pen doesn't use any external CSS resources.
This Pen doesn't use any external JavaScript resources.