用JS操作窗口(react中),触底加载,回到顶部,吸顶,下拉刷新,示例代码

本文主要是介绍用JS操作窗口(react中),触底加载,回到顶部,吸顶,下拉刷新,示例代码,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

触底加载

创建loadMore函数

应用数据

回到顶部

 监听滚动容器的 scroll 事件

window.scrollY

创建回到顶部按钮 

吸顶

创建函数

 应用元素

css样式

下拉刷新

创建新增数据函数

加载时间函数

应用元素


触底加载

创建loadMore函数
   const [hasMore,setHasMore] = useState(true)const [len,setlen] =useState(2)const loadMore=()=> {if (window.innerHeight+window.screenY>=window.screenTop-1){setTimeout(() => {setlen(len + 4)setHasMore(len < list.length)}, 2000);}   }

通过比较窗口的可视区域高度和文档的滚动距离,判断是否滚动到了页面底部。这里使用了window.innerHeight来获取可视区域的高度,window.scrollY来获取文档的滚动距离,以及window.scrollY+window.innerHeight来获取文档可视区域的底部位置。

如果滚动到了页面底部,就执行一个延迟函数,使用setTimeout设定一个延迟时间(这里延迟2秒,通过2000来表示)。

在延迟函数中,执行更新状态的操作。通过调用setlen(len + 4)来增加一个变量len的值,这里将其增加了4,表示加载了4条数据。然后,使用setHasMore(len < list.length)来更新一个变量hasMore的值,这个变量表示是否还有更多数据可加载

应用数据

引用antd-mobile中无限滚动

import { InfiniteScroll,List} from 'antd-mobile'//组件包裹数据
<List><div>{list.slice(0,len).map((item,index)=>(<span>{item}</span>))}</div></List><InfiniteScroll loadMore={loadMore} hasMore={hasMore} ></InfiniteScroll> 

回到顶部

 监听滚动容器的 scroll 事件

检测是否滚动到了底部。你可以使用 element.addEventListener('scroll', callback) 方法来注册一个监听器,其中 element 表示滚动容器元素,callback 表示在滚动事件触发时执行的函数。在该函数中,可以获取滚动容器的滚动位置和当前容器的高度、滚动条高度等信息,以判断是否已经触底(即滚动条滚动到底部)。

    const [toup, settoup] = useState(false);//用来判断是否出现回到顶部按钮useEffect(()=>{getdata()const handleScroll = () => {// 回到顶部const scrollTop = window.scrollY;const shouldScroll = scrollTop > 0;setShouldScrollToTop(shouldScroll);settoup(shouldScroll)};window.addEventListener('scroll', handleScroll);return () => {window.removeEventListener('scroll', handleScroll);};},[])
window.scrollY

是一个只读属性,用于返回窗口在垂直方向上已滚动的像素值。它提供了当前窗口垂直滚动位置的信息。

可以通过以下示例代码来获取并使用 window.scrollY 的值:

const handleScroll = () => {const scrollY = window.scrollY;console.log(scrollY); // 输出窗口垂直滚动的像素值// 进一步处理滚动事件
};
​
window.addEventListener('scroll', handleScroll);

在上面的示例中,handleScroll 函数中的 scrollY 变量将存储 window.scrollY 的当前值。你可以将其用于进一步处理滚动事件,例如更新 UI 或执行特定的操作。

请注意,window.scrollY 是只读的,因此不能将其用于更改窗口的滚动位置。如果你想要滚动窗口,请使用 window.scrollTo() 或其他相关方法。

创建回到顶部按钮 
  const backup =()=>{window.scrollTo({top:0,behavior:'smooth'})}

根据toup的布尔值来决定按钮是否出现 

<div>{toup && (<div style={{background:'orange',width:'30px',lineHeight:'30px',height:'30px',
position:'fixed',bottom:'10px',zIndex:'999'}}><ArrowUp onClick={backup}></ArrowUp></div>)}
</div>

 

吸顶

创建函数

同样也需要监听滚动容器的 scroll 事件,这里直接放入上边的函数

创建isSticky确定吸顶元素的样式

 const [isSticky, setIsSticky] = useState(false);useEffect(()=>{getdata()const handleScroll = () => {// 回到顶部const scrollTop = window.scrollY;const shouldScroll = scrollTop > 0;setShouldScrollToTop(shouldScroll);settoup(shouldScroll)// 吸顶window.scrollY > 0 ? setIsSticky(true) : setIsSticky(false);};window.addEventListener('scroll', handleScroll);return () => {window.removeEventListener('scroll', handleScroll);};},[])
 应用元素
<div className={`sticky-header ${isSticky ? 'sticky' : ''}`}><SearchBar placeholder='请输入内容' onFocus={() => {navigate('/search')}}/></div>
css样式
.sticky-header {/* Your header styles */transition: all 0.3s ease-in-out;}.sticky {position: sticky;top: 0;z-index: 999;}

 

下拉刷新

创建新增数据函数
import React, { useState } from 'react'
import { PullToRefresh, List } from 'antd-mobile'export default function Search() {function getNextData() {const ret = []for (let i = 0; i < 5; i++) {const randomNumber = Math.floor(Math.random() * 900) + 100;ret.push(randomNumber);}return ret}const [data, setData] = useState(() => getNextData())

const [data, setData] = useState(() => getNextData()):这行代码是使用 React 中的 useState 钩子来声明一个状态变量 data 和一个更新状态的函数 setDatauseState(() => getNextData()) 表示初始状态是通过调用 getNextData() 函数得到的。

useState(() => getNextData()) 是一个自执行的函数,它会在组件第一次渲染时执行一次,并返回初始的状态值。初始状态值是通过 getNextData() 函数来获取的。

加载时间函数
  function sleep(ms) {return new Promise(resolve => setTimeout(resolve, ms));
}
应用元素
 <PullToRefreshonRefresh={async () => {await sleep(1000)setData([...getNextData()])}}><List style={{ minHeight: '100vh' }}>{data.map((item, index) => (<List.Item key={index}>{item}</List.Item>))}</List></PullToRefresh>

这篇关于用JS操作窗口(react中),触底加载,回到顶部,吸顶,下拉刷新,示例代码的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/587567

相关文章

springboot项目中集成shiro+jwt完整实例代码

《springboot项目中集成shiro+jwt完整实例代码》本文详细介绍如何在项目中集成Shiro和JWT,实现用户登录校验、token携带及接口权限管理,涉及自定义Realm、ModularRe... 目录简介目的需要的jar集成过程1.配置shiro2.创建自定义Realm2.1 LoginReal

SpringBoot集成Shiro+JWT(Hutool)完整代码示例

《SpringBoot集成Shiro+JWT(Hutool)完整代码示例》ApacheShiro是一个强大且易用的Java安全框架,提供了认证、授权、加密和会话管理功能,在现代应用开发中,Shiro因... 目录一、背景介绍1.1 为什么使用Shiro?1.2 为什么需要双Token?二、技术栈组成三、环境

Java 与 LibreOffice 集成开发指南(环境搭建及代码示例)

《Java与LibreOffice集成开发指南(环境搭建及代码示例)》本文介绍Java与LibreOffice的集成方法,涵盖环境配置、API调用、文档转换、UNO桥接及REST接口等技术,提供... 目录1. 引言2. 环境搭建2.1 安装 LibreOffice2.2 配置 Java 开发环境2.3 配

Python跨文件实例化、跨文件调用及导入库示例代码

《Python跨文件实例化、跨文件调用及导入库示例代码》在Python开发过程中,经常会遇到需要在一个工程中调用另一个工程的Python文件的情况,:本文主要介绍Python跨文件实例化、跨文件调... 目录1. 核心对比表格(完整汇总)1.1 自定义模块跨文件调用汇总表1.2 第三方库使用汇总表1.3 导

基于Python Playwright进行前端性能测试的脚本实现

《基于PythonPlaywright进行前端性能测试的脚本实现》在当今Web应用开发中,性能优化是提升用户体验的关键因素之一,本文将介绍如何使用Playwright构建一个自动化性能测试工具,希望... 目录引言工具概述整体架构核心实现解析1. 浏览器初始化2. 性能数据收集3. 资源分析4. 关键性能指

Go语言使用select监听多个channel的示例详解

《Go语言使用select监听多个channel的示例详解》本文将聚焦Go并发中的一个强力工具,select,这篇文章将通过实际案例学习如何优雅地监听多个Channel,实现多任务处理、超时控制和非阻... 目录一、前言:为什么要使用select二、实战目标三、案例代码:监听两个任务结果和超时四、运行示例五

python使用Akshare与Streamlit实现股票估值分析教程(图文代码)

《python使用Akshare与Streamlit实现股票估值分析教程(图文代码)》入职测试中的一道题,要求:从Akshare下载某一个股票近十年的财务报表包括,资产负债表,利润表,现金流量表,保存... 目录一、前言二、核心知识点梳理1、Akshare数据获取2、Pandas数据处理3、Matplotl

Django开发时如何避免频繁发送短信验证码(python图文代码)

《Django开发时如何避免频繁发送短信验证码(python图文代码)》Django开发时,为防止频繁发送验证码,后端需用Redis限制请求频率,结合管道技术提升效率,通过生产者消费者模式解耦业务逻辑... 目录避免频繁发送 验证码1. www.chinasem.cn避免频繁发送 验证码逻辑分析2. 避免频繁

精选20个好玩又实用的的Python实战项目(有图文代码)

《精选20个好玩又实用的的Python实战项目(有图文代码)》文章介绍了20个实用Python项目,涵盖游戏开发、工具应用、图像处理、机器学习等,使用Tkinter、PIL、OpenCV、Kivy等库... 目录① 猜字游戏② 闹钟③ 骰子模拟器④ 二维码⑤ 语言检测⑥ 加密和解密⑦ URL缩短⑧ 音乐播放

python panda库从基础到高级操作分析

《pythonpanda库从基础到高级操作分析》本文介绍了Pandas库的核心功能,包括处理结构化数据的Series和DataFrame数据结构,数据读取、清洗、分组聚合、合并、时间序列分析及大数据... 目录1. Pandas 概述2. 基本操作:数据读取与查看3. 索引操作:精准定位数据4. Group