用JS制作博客页面背景随滚动渐变的效果
今天颓了一会,用JavaScript给我的博客园博客写了一个页面背景随滚动而渐变的效果,做完之后自我感觉良好……
下面就以我的博客园博客为例,介绍一下如何制作这个效果!
准备
- 申请博客园的JS权限(如果你也想把它用在自己的博客园上)
- 可能需要一些JS的基础知识(你可以打开w3school,然后就当自己准备好了)
- 可能需要一些CSS基础知识(你需要知道颜色是怎样用16进制表示的)
——当然,你也可以复制下面的代码然后走人……
注意:如果你想要用在自己的博客园上,请注意博客园的不同模板对应的元素class
也可能是不同的。
代码
首先,在“页首HTML代码”中新建一个div,放在最下面一层。这个div用来放渐变的背景颜色。
<div id="backGround" style="position: fixed; width:100%; height: 100%; top: 0; left: 0; background-color: #bff687; z-index: -1"></div>
然后用js监听window.onscroll
事件,记录一个cnt变量,每监听到一次,就给cnt加上1,然后用cnt生成当前颜色。
至于颜色的生成方式你可以自己发明一个。我用了三个相位不同的sin函数生成R、G、B三个颜色的值。
function getTitleValue(start, x){
var ret = titleMax - 1 - rangeValue + Math.floor(rangeValue * Math.sin(start + x));
return ret;
}
function getBackgroundColor(){
var red = getBackgroundValue(0, cnt * 2 * PI / 256).toString(16);
var green = getBackgroundValue(2 * PI / 3, cnt * 2 * PI / 256).toString(16);
var blue = getBackgroundValue(4 * PI / 3, cnt * 2 * PI / 256).toString(16);
return "#" + red + green + blue;
}
这里讲一下如何用js修改某个元素的颜色:
function changeColor(){
var backGround = document.getElementById("backGround");
var titles = document.getElementsByClassName("postTitle2");
var newTitleColor = getTilteColor();
backGround.style.backgroundColor = getBackgroundColor();
for(var i = 0; i < titles.length; i++)
titles[i].style.color = newTitleColor;
cnt = (cnt + 1) % 256;
}
先getElementById
,然后调用生成颜色的函数,生成了一个字符串,形如#aabbcc
,代表颜色。然后用JS修改CSS。
完整代码:
<div id="backGround" style="position: fixed; width:100%; height: 100%; top: 0; left: 0; background-color: #bff687; z-index: -1"></div>
<script>
var cnt = 0, PI = Math.acos(-1);
var rangeValue = 64, backgroundMax = 256, titleMax = 192;
function getBackgroundValue(start, x){
var ret = backgroundMax - 1 - rangeValue + Math.floor(rangeValue * Math.sin(start + x));
return ret;
}
function getTitleValue(start, x){
var ret = titleMax - 1 - rangeValue + Math.floor(rangeValue * Math.sin(start + x));
return ret;
}
function getBackgroundColor(){
var red = getBackgroundValue(0, cnt * 2 * PI / 256).toString(16);
var green = getBackgroundValue(2 * PI / 3, cnt * 2 * PI / 256).toString(16);
var blue = getBackgroundValue(4 * PI / 3, cnt * 2 * PI / 256).toString(16);
return "#" + red + green + blue;
}
function getTilteColor(){
var red = getTitleValue(0, cnt * 2 * PI / 256).toString(16);
var green = getTitleValue(2 * PI / 3, cnt * 2 * PI / 256).toString(16);
var blue = getTitleValue(4 * PI / 3, cnt * 2 * PI / 256).toString(16);
return "#" + red + green + blue;
}
window.onload = window.onscroll = function changeColor(){
var backGround = document.getElementById("backGround");
var titles = document.getElementsByClassName("postTitle2");
var newTitleColor = getTilteColor();
backGround.style.backgroundColor = getBackgroundColor();
for(var i = 0; i < titles.length; i++)
titles[i].style.color = newTitleColor;
cnt = (cnt + 1) % 256;
}
</script>
本文作者:胡小兔
博客地址:http://rabbithu.cnblogs.com
博客地址:http://rabbithu.cnblogs.com
标签:
不务正业
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· winform 绘制太阳,地球,月球 运作规律
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)