根据here的建议,我可以通过单击导航链接来更改CSS变量。但是,这些变化并没有持续下去。它们会暂时切换到新的样式,但随后又会切换回原来的样式。这甚至不需要页面刷新--在onmouseup之后一秒钟。
谢谢。
CSS
body {
--bg-color-home: rgba(221, 230, 237, .85);
--bg-image-home: url(../images/bg_peak.jpg);
--bg-color-about: rgba(223, 238, 243, 1);
--bg-image-about: url(../images/bg_about.jpg);
--bg-color: var(--bg-color-home);
--bg-image: var(--bg-image-home);
}
HTML
<a href="template.xhtml?page=about" data-value="about" class="nav-link">About</a>
JavaScript
//Change CSS styles, based on 'link' variable
$(document).on('click','a.nav-link',function(){
//Set link variable from 'data-value' of 'nav-link' option
var link = $("a:focus").attr('data-value');
//Set the new styles based on 'nav-link' option
$(document.body).css('--bg-color', 'var(--bg-color-' + link + ')');
$(document.body).css('--bg-image', 'var(--bg-image-' + link + ')');
});
https://stackoverflow.com/questions/51488873
复制相似问题