搜索
首页web前端css教程Userainbow()

Userainbow()

Mar 15, 2025 am 10:02 AM

本文详细介绍了个人网站Potath.Horse的彩虹背景效果的创建。作者休假以从事个人项目,他解释了效果背后的简单而有效的JavaScript代码。

Userainbow()

核心概念涉及将用户的滚动位置映射到HSL(色调,饱和度,轻度)颜色模型中的色相值。当用户浏览页面内容时,这会产生光滑的颜色过渡。提供了代码段:

导出const userainbowbg =()=>
useeffect(()=> {
  const cb =()=> {
    const viewportheight = window.innerheight
    const contentHeight = document.body.getBoundingCletRect()。高度
    const viewportsperrotation = math.min(
      3,
      contentheight / viewPotheight
    )
    const来自= 51
    const进度=
      window.scrolly /(viewPortheight * viewportsperrotation)
    const H =(来自360 *进度)%360

    document.body.style.backgroundColor =`hsl($ {h} ver,100%,50%)
  }
  window.addeventlistener('scroll',cb,{vassive:true})
  return()=> window.removeeventlistener('scroll',cb)
}))

作者将HSL模型与RGB进行了对比,突出了HSL的直观性质,以调节色彩温度和亮度。他们解释了HSL在改变色调的同时选择一致的亮度的选择,这是所需效果的关键方面。最初的色调偏移( const from = 51 )被解释为一种风格选择。

讨论了潜在的性能改进,包括避免使用冗余的getBoundingClientRect调用,并使用requestAnimationFrame进行节流。但是,作者强调了在优化之前测量性能的重要性。

该文章还解决了HSL非敏感统一性的局限性,并承认某些完全饱和的颜色可能比其他颜色更暗。作者计划在将来的迭代中使用像HSLUV一样的均匀颜色空间来解决此问题。

提到了可访问性考虑因素,重点是色盲和prefers-reduced-motion媒体查询。虽然初始测试没有任何问题,但作者承认可以将背景动画视为运动并计划进一步的用户研究的可能性。

作者结束时回顾了设计的怀旧灵感,旨在实现有趣而功能的用户体验。他们还提到了一段时间的倦怠后编码项目时遇到的乐趣。

脚注

  1. CMYK中的“ K”代表黑色,以避免与其他颜色模型中代表蓝色的“ B”混淆。
  2. 由于感知颜色空间和RGB/HSL表示之间的差异,亮度并不完全一致。

以上是Userainbow()的详细内容。更多信息请关注PHP中文网其他相关文章!

声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
两个图像和一个API:我们重新着色产品所需的一切两个图像和一个API:我们重新着色产品所需的一切Apr 15, 2025 am 11:27 AM

我最近找到了一种动态更新任何产品图像的颜色的解决方案。因此,只有一种产品之一,我们可以以不同的方式对其进行着色以显示

每周平台新闻:第三方代码,被动混合内容,连接最慢的国家的影响每周平台新闻:第三方代码,被动混合内容,连接最慢的国家的影响Apr 15, 2025 am 11:19 AM

在本周的综述中,灯塔在第三方脚本上阐明了灯光,不安全的资源将在安全站点上被阻止,许多国家连接速度

托管您自己的非JavaScript分析的选项托管您自己的非JavaScript分析的选项Apr 15, 2025 am 11:09 AM

有很多分析平台可帮助您跟踪网站上的访问者和使用数据。也许最著名的是Google Analytics(广泛使用)

它全部都在头上:管理带有React头盔的React Power Site的文档头它全部都在头上:管理带有React头盔的React Power Site的文档头Apr 15, 2025 am 11:01 AM

文档负责人可能不是网站上最迷人的部分,但是其中所处的内容对于您的网站的成功也一样重要

JavaScript中的Super()是什么?JavaScript中的Super()是什么?Apr 15, 2025 am 10:59 AM

当您看到一些称为super()的JavaScript时,在子类中,您会使用super()调用其父母的构造函数和超级。访问它的

比较不同类型的本机JavaScript弹出窗口比较不同类型的本机JavaScript弹出窗口Apr 15, 2025 am 10:48 AM

JavaScript具有各种内置弹出API,它们显示用于用户交互的特殊UI。著名:

为什么可访问的网站如此难以构建?为什么可访问的网站如此难以构建?Apr 15, 2025 am 10:45 AM

前几天,我与一些前端人们聊天,讲述了为什么这么多公司努力创建可访问的网站。为什么可访问的网站如此艰难

'隐藏”属性显然很弱'隐藏”属性显然很弱Apr 15, 2025 am 10:43 AM

有一个HTML属性,它可以正是您认为应该做的:

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
4 周前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
4 周前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您听不到任何人,如何修复音频
4 周前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.聊天命令以及如何使用它们
4 周前By尊渡假赌尊渡假赌尊渡假赌

热工具

Atom编辑器mac版下载

Atom编辑器mac版下载

最流行的的开源编辑器

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

PhpStorm Mac 版本

PhpStorm Mac 版本

最新(2018.2.1 )专业的PHP集成开发工具

SublimeText3 英文版

SublimeText3 英文版

推荐:为Win版本,支持代码提示!