这个问题可以通过自定义 js 脚本来解决,无侵入式修改。而 hexo-fluid
配置自定义的 js 文件也是比较轻松的,文档里面写得是比较清晰的,我们在
fluid 的主题配置文件里面指定一下自定义的 js 文件即可,
为了同时拥有动画效果,我们也得指定一下 css
文件,做法和上面是一样的,然后具体创建(如果原来没有的话)修改两个文件,一个是
js 文件,我们通过在网页中查看这个 html 元素,然后在 js
代码中定位到这个元素,然后作具体的修改,
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24
| var navbarWidget = document.getElementById("navbar");
function toggleNavbar() { var prevScrollPos = window.pageYOffset || document.documentElement.scrollTop; window.addEventListener('scroll', function () { var currentScrollPos = window.pageYOffset || document.documentElement.scrollTop; if (prevScrollPos > currentScrollPos) { navbarWidget.style.top = '0'; } else { navbarWidget.style.top = '-100px'; } prevScrollPos = currentScrollPos; }); };
window.onload = function () { toggleNavbar(); };
|
上面这段 js 代码其实是比较简单的,这个问一下 chatgpt
都可以得到类似的效果。
然后是动画效果,在我们的 custom.css
文件里面加入如下代码片段,
| #navbar { transition: all 0.3s; font-size: 1rem; }
.navbar .nav-item .nav-link { display: block; color: var(--navbar-text-color); transition: color 0.3s, background-color 0.3s; }
.navbar .nav-item .nav-link i { font-size: 1rem; }
|
这里我还多做了一个步骤,那就是把导航栏的字体大小调整成了
1rem
,这个其实是为了和移动端自适应的时候保持一致,那么,这样的话,浏览器在缩放宽度的时候字体的动画效果就不会因为大小的问题而产生视觉上的不好的观感。