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

sxkk20081年前知识分享93
目录

前言

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

实现逻辑

  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检测技术的重要性及应用领域探索

使用AI检测技术的重要性及应用领域探索

  随着人工智能(AI)技术的快速发展,以AI检测为中心的应用逐渐成为社会各个领域的热点。AI检测利用计算机视觉和深度学习等算法,通过自动分析和理解图像、视频或声音等数据,从...

人工智能:实现科技进步与社会进步的有机结合

人工智能:实现科技进步与社会进步的有机结合

  人工智能是一种模拟人类智能的技术和系统,旨在使计算机能够执行复杂的任务和决策。随着科技的飞速发展,人工智能已经成为一个备受关注的热门话题。它不仅在各个领域展现出了令人瞩目...

阿里人脸识别:开创人工智能时代的身份验证进程

阿里人脸识别:开创人工智能时代的身份验证进程

  近年来,随着科技的不断进步和人工智能的快速发展,人脸识别作为一种快速、准确的身份验证技术,正逐渐渗透进我们的日常生活。作为国内的互联网巨头,阿里巴巴也不甘落后,旗下的阿里...

发表评论    

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