-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathscript.js
More file actions
47 lines (40 loc) · 1.41 KB
/
script.js
File metadata and controls
47 lines (40 loc) · 1.41 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
const cards = document.querySelectorAll(".card")
const observer = new IntersectionObserver(
entries => {
entries.forEach(entry => {
entry.target.classList.toggle('show',entry.isIntersecting)
// if(entry.isIntersecting) observer.unobserve(entry.target)
})
},
{
threshold:1 , // threshold :1 => add card only when entire element is visible
}
)
cards.forEach(card => {
observer.observe(card)
})
//lazy loading (adding new cards)
// const lastCard = document.querySelector(".card:last-child")
const lastCard = document.querySelectorAll(".card")[document.querySelectorAll(".card").length-1]
const lastCardObserver = new IntersectionObserver((entries) =>{
const lastCard = entries[0]
if(!lastCard.isIntersecting) return
loadNewCards()
lastCardObserver.unobserve(lastCard.target)
// lastCardObserver.observe(document.querySelector(".card:last-child"))
lastCardObserver.observe(document.querySelectorAll(".card")[document.querySelectorAll(".card").length-1])
} ,
{
rootMargin:"100px"
})
lastCardObserver.observe(lastCard)
const cardContainer = document.querySelector('.card-container')
function loadNewCards(){
for(let i=0;i<10;i++){
const card = document.createElement('div')
card.textContent = "New Card"
card.classList.add("card")
observer.observe(card)
cardContainer.append(card)
}
}