CSS 滚动时更改导航栏背景颜色
2017-07-21
2793
我的导航栏有白色背景,但它在着陆页上应该是透明的,向下滚动时是白色的,在其他每个页面上都是白色的。
我使用的代码来自: 滚动后更改导航栏颜色?
编辑:
所以我在下面的答案中添加了一个小提琴,但不知何故它不起作用
https://jsfiddle.net/jy6njukm/
这是我的代码:
javascript:
$(document).ready(function(){
var scroll_start = 0;
var change_color = $('#change_color');
var offset = change_color.offset();
if (change_color.length){
$(document).scroll(function() {
scroll_start = $(this).scrollTop();
if(scroll_start > offset.top) {
// the white normal navbar
$(".navbar-add").removeClass("navbar-trans");
} else {
// what the users sees when he lands on the page
$(".navbar-add").addClass("navbar-trans");
}
});
}
});
这是我的导航栏css:
.navbar-fixed {
position: fixed;
height: 70px;
padding: 0px 30px;
left: 0px;
top: 0px;
z-index: 50;
width: 100%;
background-color: white;
box-shadow: 0 1px 5px 0 rgba(0,0,0,0.07),0 1px 0 0 rgba(0,0,0,0.03);
}
.navbar-trans {
background-color: transparent !important;
box-shadow: none !important;
}
我的导航栏 html 中只有
<div class="navbar-fixed navbar-add">
.....
</div>
我的 home.html.erb 中有
<div class="container-fluid banner bg-picture" id="change_color"
style="background-image: linear-gradient(-225deg, rgba(0,0,0,0.2) 0%,
rgba(0,0,0,0.35) 50%), url('<%= asset_path('banner_logo.jpeg') %>')">
</div>
这样还算可以,但现在的问题是,每次我刷新页面时,导航栏仍然是白色的,只有我向上滚动到页面顶部时,它才会变成透明的。但是当我向下滚动时,它会变成白色,就像我想要的那样。
我检查了页面,每次刷新时,类的背景颜色仍然是白色的,即使我在 javascript 中将其设置为透明?
如何才能使我的导航栏的背景颜色在我的着陆页上透明?
1个回答
使用html
您的html应该是:
254945530
,因为它已经包含
navbar-trans
类,将保持透明。用户滚动后,JavaScript将启动,并根据代码删除/添加
navbar-trans
类。代码>
在这里,除了绑定
updatenavstyle
函数外,我还添加了一个呼叫,一旦DOM准备就绪。结果,一旦页面加载,该函数将被执行一次,并且将根据滚动位置应用样式。
更新:
如果您的着陆页是' index.html',在您希望此函数起作用的情况下,将其值写入变量
landingpage
。因此,该函数不会在其他页面中运行
Nisarg Shah
2017-07-21