CSS实现表格无限轮播

<div className={styles.tableTh}>
  <div className={styles.thItem} style={{ width: '40%' }}>报警名称</div>
  <div className={styles.thItem} style={{ width: '35%' }}>开始时间</div>
  <div className={styles.thItem} style={{ width: '25%' }}>状态</div>
  </div>
     <div className={styles.tableBody} ref={scrollRef}>
        {alarmTableList.map((item, index) => {
           return (
             <div className={styles.bodyContent} key={index}>
               <div style={{ width: '40%' }}>{item?.name}</div>
               <div style={{ width: '35%' }}>{item?.time}</div>
               <div style={{ width: '25%', color: item?.status === 0 ? '#12fd00' : '#f62222' }}>{item?.status === 0 ? '报警' : '正常'}</div>
             </div>
            );
         })}
     </div>
      .tableTh {
        width: 100%;
        height: 36px;
        line-height: 36px;
        text-align: center;
        background-color: #2e3646;
        display: flex;
        justify-content: flex-start;
        .thItem {
          font-weight: bold;
          font-size: 16px;
          letter-spacing: 1px;
          color: #bae7ff;
          &:first-child {
            border-right: 1px solid #5a6477;
          }
          &:nth-child(2) {
            border-right: 1px solid #5a6477;
          }
        }
      }
      .tableBody {
        width: 100%;
        height: 86%;
        overflow: hidden;
        text-align: center;
        .bodyContent {
          font-size: 18px;
          display: flex;
          justify-content: flex-start;
          padding: 8px 0;
          &:nth-child(even) {
            background-color: #2e3646;
          }
        }
      }
  const scrollRef = useRef(null); // 用于表格滚动
  const [scrollTop, setScrollTop] = useState(0);
 const [alarmTableList, setAlarmTableList] = useState([]); // 表格数据

  // 滚动动画的函数
  const scrollAnimation = () => {
    if (scrollRef.current) {
      // 每次滚动的高度
      const step = 1;
      // 更新scrollTop的值
      setScrollTop((prevScrollTop) => {
        // 当滚动到内容底部时,重置滚动位置到顶部
        if (prevScrollTop >= scrollRef.current.scrollHeight - scrollRef.current.clientHeight) {
          return 0;
        }
        return prevScrollTop + step;
      });
    }
  };

useEffect(() => {
    const tableArr = [];
    for (let i = 1; i <= 32; i++) {
      let obj = {
        name: i + '级报警',
        time: '09:23',
        status: i % 2 === 0 ? 1 : 0, // 0:报警
      };
      tableArr.push(obj);
    }
    setAlarmTableList(tableArr);
   const intervalId = setInterval(scrollAnimation, 50); // 每50毫秒滚动一次
    return () => {
      clearInterval(intervalId); // 组件卸载时清除定时器
      autofit.off();
    };
  }, []); // 当scrollTop变化时,重新设置滚动位置

  useEffect(() => {
    if (scrollRef.current) {
      // 设置scrollRef的scrollTop属性来滚动内容
      scrollRef.current.scrollTop = scrollTop;
    }
  }, [scrollTop]); // 当scrollTop变化时,重新设置滚动位置

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
HTML和CSS可以结合使用,再加上JavaScript(如果需要动态效果)来实现图片轮播功能。以下是一个基本的步骤和示例代码: 1. **HTML结构**: ```html <div class="slideshow-container"> <div class="slide"> <img src="image1.jpg" alt="Image 1"> </div> <div class="slide"> <img src="image2.jpg" alt="Image 2"> </div> <!-- 更多图片 --> </div> ``` 2. **CSS样式**: ```css .slideshow-container { position: relative; width: 100%; height: 400px; overflow: hidden; } .slide { position: absolute; display: none; } .slide.active { display: block; } ``` 3. **JavaScript (可选, CSS3动画实现轮播)**: 无JavaScript的情况下,可以通过CSS3的`transition`或`animation`实现简单的轮播效果。例如,使用关键帧动画: ```css .slide { transition: transform 2s ease-in-out; } .slide.active { transform: translateX(0); } .slide.next { transform: translateX(-100%); } /* 添加按钮切换事件 */ <button onclick="changeSlide(-1)">Prev</button> <button onclick="changeSlide(1)">Next</button> ``` 4. **JavaScript 动态切换图片**: ```javascript function changeSlide(direction) { var slides = document.querySelectorAll('.slide'); var currentSlide = slides[slides.length * direction]; // 根据方向获取当前显示的图片 // 切换显示状态 currentSlide.classList.remove('active'); currentSlide.classList.add('next'); // 获取下一张/上一张并切换 var nextSlide = slides[slides.length * direction + 1]; if (nextSlide) { nextSlide.classList.remove('next'); nextSlide.classList.add('active'); } } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值