Я работаю над javascript Свойством IntersectionObserver.
Я хочу получить цвета из массива colors
, чтобы поместить сюда entry.target.style.backgroundColor= col; //changing to background color to the color from colors array
в функцию action
. Но я получаю только следующие значения: blue
, который является последним из массива colors
.
Как я могу получить каждый цвет из массива и привести его в действие? Кроме того, возможно ли вернуть цвет к исходному цвету фона при прокрутке назад?
const sections = document.querySelectorAll('section');
const colors = ['green','brown', 'blue'];
for(let i=0; i < colors.length; i ++) {
col = colors[i];
}
const action = function (entries) {
entries.forEach(entry => {
if(entry.isIntersecting) {
entry.target.style.backgroundColor= col; //changing to background color to the color from colors array
} else {
return false; // going back to original background color???
}
});
}
const options = {
root: null,
rootMargin: "30% 0px",
threshold: 1
};
const observer = new IntersectionObserver(action, options);
sections.forEach(section => {
observer.observe(section);
});
header { height: 100vh; background: #ccc;}
.block {
position: relative;
width: 100%;
height: 100vh;
transition: .5s;
}
.block1 {background: #666;}
.block2 { background: #aaa;}
.block3 { background: #333;}
<header>header</header>
<section class="block block1">green</section>
<section class="block block2">brown</section>
<section class="block block3">blue</section>