@TinaLee

Как сделать так, чтобы прокрутка div и прокрутка body работали одновременно, несмотря на длину содержимого?

У меня синхронизация прокрутки div и прокрутки body. Но мне нужна еще помощь, чтобы прокрутить div и body одновременно вверх и вниз, даже если div будет прокручиваться медленно. Как на этом сайте https://alakel.kg Если вы заметили, то боковая панель прокручивается медленно, но одновременно с основной прокруткой. Вот мой код на https://codesandbox.io/s/spring-cdn-i875c?file=/sr... . Буду рад, если вы мне поможете.

import { Fragment, useEffect, useRef, useState } from "react";
import "./styles.css";
export default function App() {
  const firstDivRef = useRef();

  const [scrollTop, setScrollTop] = useState(0);
  const [disableBodyScroll, setDisableBodyScroll] = useState(false);
  const handleScrollFirst = (scroll) => {
    setScrollTop(scroll.target.scrollTop);
  };

  useEffect(() => {
    if (firstDivRef.current && !disableBodyScroll) {
      firstDivRef.current.scrollTop = scrollTop;
    }
    if (disableBodyScroll) {
      window.scrollTo(0, scrollTop);
    }
  }, [firstDivRef, scrollTop, disableBodyScroll]);

  useEffect(() => {
    const onScroll = () => {
      console.log(disableBodyScroll, window.scrollY);

      if (!disableBodyScroll) {
        setScrollTop(window.scrollY);
      }
    };
    // clean up code
    window.removeEventListener("scroll", onScroll);
    window.addEventListener("scroll", onScroll);
    return () => window.removeEventListener("scroll", onScroll);
  }, [disableBodyScroll]);

  return (
    <Fragment>
    <div className="header"></div>
    <div
      className="App"
      style={{
        display: "flex",
        marginTop: "100px"
      }}>
   
      <div
        onMouseEnter={() => setDisableBodyScroll(true)}
        onMouseLeave={() => setDisableBodyScroll(false)}
        onScroll={handleScrollFirst}
        ref={firstDivRef}
        style={{
          height: "600px",
          overflow: "scroll",
          backgroundColor: "#FFDAB9",
          position: "sticky",
          top: "100px"
        }}>
        <div>
          <ul className="first-scroll">
            <li>Scroll text</li>
            <li>Scroll text</li>
            <li>Scroll text</li>
            <li>Scroll text</li>
            <li>Scroll text</li>
            <li>Scroll text</li>
            <li>Scroll text</li>
            <li>Scroll text</li>
            <li>Scroll text</li>
            <li>Scroll text</li>
            <li>Scroll text</li>
            <li>Scroll text</li>
            <li>Scroll text</li>
            <li>Scroll text</li>
            <li>Scroll text</li>
          </ul>
        </div>
      </div>

      <div style={{
          backgroundColor: "#EEE8AA"
        }}>
        <div>
          <ul className="first-scroll">
            <li>Scroll text</li>
            <li>Scroll text</li>
            <li>Scroll text</li>
            <li>Scroll text</li>
            <li>Scroll text</li>
            <li>Scroll text</li>
            <li>Scroll text</li>
            <li>Scroll text</li>
            <li>Scroll text</li>
            <li>Scroll text</li>
            <li>Scroll text</li>
            <li>Scroll text</li>
            <li>Scroll text</li>
            <li>Scroll text</li>
            <li>Scroll text</li>
            <li>Scroll text</li>
            <li>Scroll text</li>
            <li>Scroll text</li>
            <li>Scroll text</li>
            <li>Scroll text</li>
            <li>Scroll text</li>
            <li>Scroll text</li>
            <li>Scroll text</li>
            <li>Scroll text</li>
            <li>Scroll text</li>
            <li>Scroll text</li>
            <li>Scroll text</li>
            <li>Scroll text</li>
            <li>Scroll text</li>
            <li>Scroll text</li>
            <li>Scroll text</li>
          </ul>
        </div>
      </div>
    </div>
    <div className="about-us"></div>
    <div className="footer"></div>
    </Fragment>
  );
}


И css код
.first-scroll{
  list-style: none;
}

.first-scroll li{
  padding: 20px 40px;
  margin: 20px 0;
  border: 1px solid red;
}

.header{
  width: 100%;
  height: 100px;
  background-color: blueviolet;
  position: fixed;
  top: 0;
  z-index: 10;
}

.footer{
  width: 100%;
  height: 200px;
  background-color: darkblue;
}

.about-us{
  width: 100%;
  height: 100px;
  background-color: rgb(0, 139, 132);
}
  • Вопрос задан
  • 108 просмотров
Решения вопроса 1
chincharovpc
@chincharovpc
Если я правильно тебя понял, то вот
import { Fragment, useEffect, useRef, useState } from "react";
import "./styles.css";
export default function App() {
  const firstDivRef = useRef();
  const [windowScroll, setWindowScroll] = useState(0);

  useEffect(() => {
    const onScroll = () => {
      if (windowScroll === 0) {
        setWindowScroll(window.scrollY);
      }

      firstDivRef.current.scrollTop =
        firstDivRef.current.scrollTop + (window.scrollY - windowScroll);

      setWindowScroll(window.scrollY);
    };

    window.removeEventListener("scroll", onScroll);
    window.addEventListener("scroll", onScroll);
    return () => window.removeEventListener("scroll", onScroll);
  }, [windowScroll]);

  return (
    <Fragment>
      <div className="header"></div>
      <div
        className="App"
        style={{
          display: "flex",
          marginTop: "100px"
        }}
      >
        <div
          ref={firstDivRef}
          style={{
            height: "600px",
            overflow: "scroll",
            backgroundColor: "#FFDAB9",
            position: "sticky",
            top: "100px"
          }}
        >
          <div>
            <ul className="first-scroll">
              <li>Scroll text</li>
              <li>Scroll text</li>
              <li>Scroll text</li>
              <li>Scroll text</li>
              <li>Scroll text</li>
              <li>Scroll text</li>
              <li>Scroll text</li>
              <li>Scroll text</li>
              <li>Scroll text</li>
              <li>Scroll text</li>
              <li>Scroll text</li>
              <li>Scroll text</li>
              <li>Scroll text</li>
              <li>Scroll text</li>
              <li>Scroll text</li>
            </ul>
          </div>
        </div>

        <div
          style={{
            backgroundColor: "#EEE8AA"
          }}
        >
          <div>
            <ul className="first-scroll">
              <li>Scroll text</li>
              <li>Scroll text</li>
              <li>Scroll text</li>
              <li>Scroll text</li>
              <li>Scroll text</li>
              <li>Scroll text</li>
              <li>Scroll text</li>
              <li>Scroll text</li>
              <li>Scroll text</li>
              <li>Scroll text</li>
              <li>Scroll text</li>
              <li>Scroll text</li>
              <li>Scroll text</li>
              <li>Scroll text</li>
              <li>Scroll text</li>
              <li>Scroll text</li>
              <li>Scroll text</li>
              <li>Scroll text</li>
              <li>Scroll text</li>
              <li>Scroll text</li>
              <li>Scroll text</li>
              <li>Scroll text</li>
              <li>Scroll text</li>
              <li>Scroll text</li>
              <li>Scroll text</li>
              <li>Scroll text</li>
              <li>Scroll text</li>
              <li>Scroll text</li>
              <li>Scroll text</li>
              <li>Scroll text</li>
              <li>Scroll text</li>
            </ul>
          </div>
        </div>
      </div>
      <div className="about-us"></div>
      <div className="footer"></div>
    </Fragment>
  );
}
Ответ написан
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Войти через центр авторизации
Похожие вопросы