js预加载和滚动到底部加载数据实现

<!DOCTYPE html>

<html lang="en">

<head>

<meta charset="UTF-8">

<meta name="viewport" content="width=device-width, initial-scale=1.0">

<title>Document</title>

<style>

* {

margin: 0;

padding: 0;

}

ul {

min-height: 500px;

position: relative;

margin: 0 auto;

}

ul li {

float: left;

padding: 5px;

list-style: none;

}

ul li img {

width: 200px;

border: 1px solid #ccc;

border-radius: 10px;

padding: 10px;

}

</style>

<script src="./myjson.js"></script>

</head>

<body>

<ul id="myList"></ul>

<script>

let ul = document.querySelector('ul')

let tableData = JSON.parse(JSON.stringify(imglist)).slice(0, 20)

render(tableData)

// 预加载 需要一个默认图片

function render(data) {

let str = ''

data.forEach((item, index) => {

// console.log(item)

str +=

`<li><img class='img-item${index}' src='./default.jpg' /></li>`

});

ul.innerHTML = str

setTimeout(() => {

loopload(data)

})

}

// 预加载函数

function loopload(data, i = 0) {

// 获取当前这条数据

let it = data[i]

if (it) {

// 创建img标签

let img = new Image()

// 设置src 缓存

img.src = it.src

// 图片加载完成以后 缓存结束 那么就应该设置到页面当中

img.onload = () => {

document.querySelector(`.img-item${i}`).src = it.src

loopload(data, i + 1)

}

}

}

//滚动到底部加载数据关键在于获取scrollTop,scrollHeight,clientHeight,监听到底部后就数据添加或者截取总数据,然后渲染

let num = 20

window.onscroll = () => {

let nowTop = document.documentElement.scrollTop

let maxTop = document.documentElement.scrollHeight

let clientHeight = document.documentElement.clientHeight

// console.log(nowTop+clientHeight,maxTop )

if (nowTop + clientHeight >= maxTop) {

num += 10

console.log('你改加载更多数据了')

let data = imglist.slice(num - 10, num)

moreRender(data)

}

}

function moreRender(data) {

let str = ''

let num = tableData.length

data.forEach((item, index) => {

// console.log(item)

str +=

`<li><img class='img-item${tableData.length + index}' src='./default.jpg' /></li>`

});

ul.innerHTML += str

tableData = [...tableData, ...data]

setTimeout(() => {

loopload(tableData)

})

}

</script>

</body>

</html>

相关推荐
axng pmje9 分钟前
Java语法进阶
java·开发语言·jvm
老前端的功夫23 分钟前
【Java从入门到入土】28:Stream API:告别for循环的新时代
java·开发语言·python
qq_4352879223 分钟前
第9章 夸父逐日与后羿射日:死循环与进程终止?十个太阳同时值班的并行冲突
java·开发语言·git·死循环·进程终止·并行冲突·夸父逐日
止语Lab36 分钟前
从手动到框架:Go DI 演进的三个拐点
开发语言·后端·golang
yaoxin5211231 小时前
397. Java 文件操作基础 - 创建常规文件与临时文件
java·开发语言·python
小短腿的代码世界1 小时前
Qt日志系统深度解析:从qDebug到企业级日志框架
开发语言·qt
前端摸鱼匠1 小时前
Vue 3 的v-bind合并行为:讲解v-bind与普通属性合并的规则
前端·javascript·vue.js·前端框架·ecmascript
REDcker2 小时前
浏览器端Web程序性能分析与优化实战 DevTools指标与工程清单
开发语言·前端·javascript·vue·ecmascript·php·js
donecoding3 小时前
一个 sudo 引发的血案:npm 全局包权限错乱彻底修复
前端·node.js·前端工程化
我命由我123453 小时前
Kotlin 开发 - lateinit 关键字
android·java·开发语言·kotlin·android studio·android-studio·android runtime