我有一个向下链接,当用户点击时,该页面将页面移动到网站的下一部分。当用户开始滚动时,如何将此渐变变为回到顶部按钮。是否还有一种方法可以将其固定到位。猜测这将通过Jquery完成,但不太确定。
<div class="down-link"><a href="#about" id="w-downlink"><i class="ss-navigatedown"></i></a></div>
.down-link {
width:100%;
height:50px;
}
#w-downlink i {
line-height: 42px;
font-size: 24px;
color: #fff;
display: block;
width: 24px;
margin: 0 auto;
margin-top:10px;
}
#w-downlink {
height: 60px;
width: 60px;
background-color: #191919;
background-color: rgba(20, 20, 20, 0.4);
position:absolute;
bottom:0;
margin-bottom:30px;
right:0;
margin-right:20px;
cursor: pointer;
-webkit-transform: translate3d(0, 0, 0);
opacity: 1;
}
.w-downlink:hover {
height: 60px;
width: 60px;
background-color: #191919;
background-color: rgba(20, 20, 20, 0.4);
position:absolute;
bottom:0;
margin-bottom:30px;
right:0;
margin-right:20px;
cursor: pointer;
-webkit-transform: translate3d(0, 0, 0);
opacity: 0.5;
}
答案 0 :(得分:2)
这应该达到你想要的大部分;你不需要jQuery。
有一个固定在页面顶部的按钮,当你开始滚动时它会改变;这只是CSS char
JS只是在position: fixed;
对象上侦听滚动事件。
我刚刚编辑了它,一旦用户通过添加window
语句向上滚动页面来检查垂直滚动,也会更改回来。
您可以将不同的元素转储到div中,而不是像我在这里一样将字符串转储到内部HTML中。
如果您希望元素淡出,请查看CSS过渡。
您可以在滚动事件开始时更改它的类,或者使用javascript完成所有操作。
以下是一些可能有助于W3C的资源:
if(){}
var downLink = document.getElementById('down-link');
window.addEventListener("scroll", function(){//Provide a window listener
if(window.scrollY){
downLink.innerHTML = "Back to Top";
}else{
downLink.innerHTML = "Down Link";
}
});
#down-link {
position: fixed;
top: 0;
left: 0;
border: 2px solid black /*Just to show the element bounds*/
}
#userScrollElement {
max-height: 500px;
height: 800px;
overflow: auto;
}