react不到一百行代码写了个pc端超简单全屏滚动fullpage

刚接触react,边看文档边动手,写了个简单的pc端全屏滚动,只支持竖屏滚动,带小圆点(nav)

fullpage.jsx文件

import React from "react";
import "./fullpage.less";
import {
    throttle } from "utils/loadash";

class Fullpage extends React.Component {
   
  constructor(props) {
   
    super(props);
    this.state = {
   
      currentPage: 1,
      pageList: this.props.children,
    };

    this.initPageListFromPropsChildren(); // 类似于vue的插槽,props带过来的children(FullpageItem)
    this.handleScroll = throttle(this.handleScroll, 600, true); //屏幕滚动时的节流函数
  }
  debounceHandleScroll = (e) => {
   
    e.persist();
    this.handleScroll(e);
  };
  changeCurrentPage(index) {
   
    this.setState({
    currentPage: index });
  }
  handleScroll(e) {
   
    if (e.deltaY > 0) {
   
      if (this.state.currentPage === this.state.pageList.length) return;
      this.changeCurrentPage(
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值