使用 React 和 Tailwind 创建阅读进度条

sxkk20082年前知识分享204
目录

前言

我们在上网的时候经常会看到一些优秀的博客顶部有个进度条,这个进度条有助于读者衡量阅读进度,我认为这个功能可以带来良好的用户体验,所以,应该将其添加到我个人博客上的文章中。那么,一起来实现吧。

实现逻辑

  1. 获取页面可以滚动的高度.
  2. 获取页面已经滚动的高度.
  3. 阅读进度=已经滚动的高度/页面可以滚动的高度

代码

单独定义一个 react hook 来活动当前的阅读进度

import { useEffect, useState } from 'react'

export function useReadingProgress() {
  const [progress, setProgress] = useState(0)
  useEffect(() => {
    function updateScroll() {
      // 已经滚动的高度
      const currentScrollY = window.scrollY
      // 可以滚动的高度
      let scrollHeight = document.body.scrollHeight - window.innerHeight
      if (scrollHeight) {
        setProgress(Number((currentScrollY / scrollHeight).toFixed(2)) * 100)
      }
    }
    // 添加全局滚动事件的监听
    window.addEventListener('scroll', updateScroll)

    // 移除监听
    return () => {
      window.removeEventListener('scroll', updateScroll)
    }
  }, [])
  return progress
}

剩下的工作是将进度显示在页面上,为此,我在顶部的导航栏上显示一个进度条。

样式

我的博客使用了 TailwindCSS,用它制作进度条非常容易

export default function ProgressBar() {
  const progress = useReadingProgress()
  return (
    <div
      style={{
        transform: `translateX(${progress - 100}%)`,
      }}
      className="fixed top-0 left-0 h-1 w-full bg-primary-500 backdrop-blur-3xl transition-transform duration-150"
    />
  )
}

我在这里使用 transform 和 translate 属性来制作进度条.

进度为 0 向左偏移 100% ,进度为 100 偏移 0,所以使用 translateX(${progress - 100}%)

以上就是本文全部内容,希望这篇文章对大家有所帮助,也可以参考我往期的文章或者在评论区交流你的想法和心得,欢迎一起探索前端。

相关文章

大方智能——赋能AI智能化发展的引领者

大方智能——赋能AI智能化发展的引领者

  在当今数字化时代,人工智能(AI)已成为引领科技进步和经济发展的关键核心。而在AI技术的应用与实践中,大方智能作为一家创新的科技企业,以其领先的技术实力和卓越的解决方案,...

智能AI人脸识别——打开未来智慧面孔的大门

智能AI人脸识别——打开未来智慧面孔的大门

  人工智能技术在如今的社会中得到了广泛的应用,其中之一便是人脸识别技术。借助这项技术,我们不仅能够确保个人信息和资产的安全,还能够提供更加个性化和便利的服务。针对此需求,许...

语音识别SDK:打造智能语音交互的先驱技术

语音识别SDK:打造智能语音交互的先驱技术

  随着科技的飞速发展,语音识别技术的普及越来越广泛,人们对于语音交互的需求也日益增长。而在这一领域中,语音识别SDK作为关键技术之一,正扮演着不可或缺的角色。本文将围绕语音...

AI人工智能网站的重要性及应用领域:连接世界的知识和信息平台

AI人工智能网站的重要性及应用领域:连接世界的知识和信息平台

  随着科技的不断发展,人工智能(AI)正逐渐渗透到我们生活的方方面面。AI技术的普及使得各类AI人工智能网站成为了人们获取信息、进行交流和实现自我提升的重要平台。在这篇文章...

铁血人

铁血人

月饼的来历2023-11-22阅读(164)苹果踏雪定制1.0/2.0官网下载更新地址激活授权签名码卡密一键批量无限多开2023-12-24阅读(115)苹果钟无艳1.0/2.0赵子龙同款微信多开标签...

百度语音,助力人工智能发展的重要引擎

百度语音,助力人工智能发展的重要引擎

  在当今信息爆炸的时代,人工智能正以前所未有的速度迅猛发展,而其中的新媒体领域更是焕发出勃勃生机。作为新媒体风格的中坚力量,百度语音凭借着其出色的语音技术,成为了人工智能发...

发表评论    

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。