如何给个人博客网站加一个炫酷的背景?

本文章的方法适用于纯色背景和HEXO里面的Chic主题

本文章同步发在我的个人博客网Hans'BLOOOOG

如何给个人博客网站加一个炫酷的背景?| Hans’BLOOOOG

某一天在逛GITHUB Chic主题issue的时候偶然发现一位大佬的网站背景变成了一些几何线条,而且还会跟随鼠标汇聚和散开,富有科技感,而且这样的线条也给Chic单调的背景增加几分动态的美感,为此,我心动了!事不宜迟,请看下文!

大佬的博客网站CY’s Blog

背景部署

代码借鉴

这样复杂而又难懂的代码对于我这个前端小白来说完全手撕出来是不太可能的啦,那我们实现的办法只能是前往大佬GITHUB主页寻找到关键代码了

在大佬index.html文件往下翻个几百行后,终于找到了我们需要的背景代码了,关键代码如下:

<script>
!
function() {
    function n(n, e, t) {
        return n.getAttribute(e) || t
    }
    function e(n) {
        return document.getElementsByTagName(n)
    }
    function t() {
        var t = e("script"),
        o = t.length,
        i = t[o - 1];
        return {
            l: o,
            z: n(i, "zIndex", -1),     //置于主页面背后
            o: n(i, "opacity", .5),     //线条透明度
            c: n(i, "color", "0,0,0"),  //线条颜色
            n: n(i, "count", 100)    //线条数量
        }
    }
    function o() {
        a = m.width = window.innerWidth || document.documentElement.clientWidth || document.body.clientWidth,
        c = m.height = window.innerHeight || document.documentElement.clientHeight || document.body.clientHeight
    }
    function i() {
        r.clearRect(0, 0, a, c);
        var n, e, t, o, m, l;
        s.forEach(function(i, x) {
            for (i.x += i.xa, i.y += i.ya, i.xa *= i.x > a || i.x < 0 ? -1 : 1, i.ya *= i.y > c || i.y < 0 ? -1 : 1, r.fillRect(i.x - .5, i.y - .5, 1, 1), e = x + 1; e < u.length; e++) n = u[e],
            null !== n.x && null !== n.y && (o = i.x - n.x, m = i.y - n.y, l = o * o + m * m, l < n.max && (n === y && l >= n.max / 2 && (i.x -= .03 * o, i.y -= .03 * m), t = (n.max - l) / n.max, r.beginPath(), r.lineWidth = t / 2, r.strokeStyle = "rgba(" + d.c + "," + (t + .2) + ")", r.moveTo(i.x, i.y), r.lineTo(n.x, n.y), r.stroke()))
        }),
        x(i)
    }
    var a, c, u, m = document.createElement("canvas"),
    d = t(),
    l = "c_n" + d.l,
    r = m.getContext("2d"),
    x = window.requestAnimationFrame || window.webkitRequestAnimationFrame || window.mozRequestAnimationFrame || window.oRequestAnimationFrame || window.msRequestAnimationFrame ||
    function(n) {
        window.setTimeout(n, 1e3 / 45)
    },
    w = Math.random,
    y = {
        x: null,
        y: null,
        max: 2e4
    };
    m.id = l,
    m.style.cssText = "position:fixed;top:0;left:0;z-index:" + d.z + ";opacity:" + d.o,
    e("body")[0].appendChild(m),
    o(),
    window.onresize = o,
    window.onmousemove = function(n) {
        n = n || window.event,
        y.x = n.clientX,
        y.y = n.clientY
    },
    window.onmouseout = function() {
        y.x = null,
        y.y = null
    };
    for (var s = [], f = 0; d.n > f; f++) {
        var h = w() * a,
        g = w() * c,
        v = 2 * w() - 1,
        p = 2 * w() - 1;
        s.push({
            x: h,
            y: g,
            xa: v,
            ya: p,
            max: 6e3
        })
    }
    u = s.concat([y]),
    setTimeout(function() {
        i()
    },
    100)
} ();
</script>

有了代码后,我们下一步就是部署代码了。

部署代码

按照文件路径themes\Chic\layout\_plugins打开,我们创建一个ejs文件background.ejs(这里自己随意命名),进入编辑文件,把我们上述的代码全部复制粘贴到里面,完成这一步后我们回到layout文件夹,在我们需要的页面加上下面一句代码即可。

<%- partial("/_plugins/background") %>  

例如我们需要把我们所有文章的背景设置为上述说的,我们就需要把这句话加到post.ejs,如果需要加载page页面、category页面、tag页面…同理只需要编辑相应的ejs文件,加入上述一句代码即可

夜间模式

到这一步可以说基本实现开篇的效果了,但是当我打开夜间模式的时候,两眼一黑,模糊的线条与背景融为一体,也就是在夜间模式下,效果还是没出来,下面我们将解决这个问题

需要解决解决夜间模式下也能看得清楚,我们就需要改变夜间模式下线条的颜色,而线条颜色的定义在function t()函数里面,找到 function t()函数,把函数改为

function t() {
        var t = e("script"),
        o = t.length,
        i = t[o - 1];

        const theme = document.body.classList.contains('dark-theme') ? 'dark' : 'light';
        if(theme==="dark")
            color = "255,255,255";
        else
            color = "0,0,0";

        return {
            l: o,
            z: n(i, "zIndex", -1),     //置于主页面背后
            o: n(i, "opacity", .5),     //线条透明度
            c: n(i, "color", color),  //线条颜色
            n: n(i, "count", 100)    //线条数量
        }
    }

改了这个函数后,原本以为应该能够解决问题了,但是当我按下按键,还是没有改变,需要对页面重新刷新后,才能有效果出来,OK,那我们就做一个识别按到切换按键,就给它来一次页面刷新,代码如下:

// Update theme when theme switcher is clicked
const toggleDesktop = document.querySelector('label[for="switch_default"]');
const toggleMobile = document.querySelector('#mobile-toggle-theme');

if (toggleDesktop) {
    toggleDesktop.addEventListener('click', function() {
        location.reload();
    });
}

if (toggleMobile) {
    toggleMobile.addEventListener('click', function() {
        location.reload();
    });
}

把这一串代码加到for循环后面即可,至此,已经能够实现这一酷酷的背景了,赶快去试试吧。

[提示]把鼠标放在一个地方不动,稳定后再快速动鼠标,有惊喜哦!

(新手第一次写博客,如有错误和不好的地方,请多担待,另外对程序有问题请提出噢!)

该个人网站一共有8个页面。首先博客的登录界面login.html:是利用html5和css3结合写出的一个炫酷的页面,根据canvas粒子制作出背景具有动态的效果。登陆后根据存入数据进行比对,对其用户名、密码、验证码验证,只有通过验证后才能登录成功并且验证成功后可以达到全屏的效果。每一个页面分为footer body和footer三部分组成。头部主要就是标题栏,尾部是页脚,中间就是主题内容。index.html主页:主要就利用js焦点滚动式轮播插入图片和文字自行进行翻页,其他主要利用div和css进行控制每一个内容框。利用链接跳转到相对应的内容上。可以根据标题、标签、关键字等点击到另一个内容,图片和文字进行有个布局达到图文环绕的布局。再然后,就是 关于about.html页面:博主简介利用jquery焦点缩略图轮播滚动类似选项卡滑动切换。可以自动展现不同的图片。其次,是成长页面about.html:是博主对未来的美好未来的期待,利用bootstrap响应式布局进行布局,图片和文章不同布局相结合,是整体更协调。再其次,是娱乐fun.html页面,利用CSS3 transform当鼠标悬停到照片上时,图片具有放大特效,主要利用css3中scale()和rotate()进行旋转和缩放。接下来是说说moodlist.html:个人心情页面,博主可以发一些类似于微信或qq心情说说,具有时间年轮的效果,当鼠标放上某一个时具有高亮的效果。最后是留言comment.html页面,可以通过给博主留言。给博主一些意见,该留言可以有表情添,留言框带有头像。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值