У меня есть простой шаблон выбора цвета stati c ниже, я хочу сделать его максимально простым. Я хочу, чтобы при наведении на .color-area
мне нужно было получить значение цвета. На самом деле мне нужно получить значение цвета экрана, где моя мышь на самом деле.
Опять же, когда я нажимаю на .hue-bar-value
, мне нужно получить цвет и изменить значение .color-area
. (Я не хочу использовать какие-либо сторонние библиотеки или плагины, я хочу это в чистом javascript)
Я просто хочу сделать это без холста.
*,
*::before,
*::after
{
box-sizing: border-box;
}
body{
margin: 0;
line-height: 1.5;
font-weight: 400;
font-size: 1rem;
font-family: "Helvetica", Segoe UI, Sans-serif;
}
.html-color-picker
{
position: relative;
width: 100%;
max-width: 250px;
height: auto;
margin: 2rem auto;
box-shadow: 0 0 8px #ddd;
}
.color-area
{
position: relative;
width: 100%;
height: 150px;
background-color: #fff;
border-bottom: 1px solid #d1d5da;
cursor: pointer;
}
.background-color
{
position: absolute;
top: 0;
left: 0;
height: 100%;
width: 100%;
background-color: #007bff;
}
.background-black{
position: absolute;
top: 0;
left: 0;
height: 100%;
width: 100%;
background-image: linear-gradient(0deg,rgb(0, 0, 0),rgba(0, 0, 0, 0));
z-index: 1;
}
.background-white{
position: absolute;
top: 0;
left: 0;
height: 100%;
width: 100%;
background-image: linear-gradient(90deg,rgb(255, 255, 255),rgba(255, 255, 255, 0));
}
.color-controller{
padding: 1rem;
font-size: 13px;
letter-spacing: .5px;
}
.hue-bar{
position: relative;
margin-bottom: 1rem;
}
.hue-bar-value{
height: 10px;
width: 100%;
background-image: linear-gradient(90deg,rgb(255, 0, 0) 0,rgb(255, 255, 0) 17%,rgb(0, 255, 0) 33%,rgb(0, 255, 255) 50%,rgb(0, 0, 255) 67%,rgb(255, 0, 255) 83%,rgb(255, 0, 0));
cursor: pointer;
}
.output{
border: 1px dotted #ddd;
padding: .25rem 1rem;
}
.output:focus{
outline: 0;
}
<div class="html-color-picker">
<div class="color-area">
<div class="background-color"></div>
<div class="background-black"></div>
<div class="background-white"></div>
</div>
<div class="color-controller">
<div class="hue-bar">
<div class="hue-bar-value"></div>
</div>
<div class="output" contenteditable="true">
#007bff
</div>
</div>
</div>