主要是从一个元素过渡到另一个元素,不想display:block/none这样太突兀,有个平滑地过渡
滑动条向下拉 一个元素慢慢变小,另一个渐渐出现
主要是从一个元素过渡到另一个元素,不想display:block/none这样太突兀,有个平滑地过渡
滑动条向下拉 一个元素慢慢变小,另一个渐渐出现
你可以控制高度啊。动画效果改变div的高度:
@keyframes H_change
{
from {height: 100%;}
to {height: 0;}
}
//向下滚动 背景图片变大 变模糊
//向上滚动 还原. 那些参数自己调试的
$(document).bind("scroll",function(){
clearTimeout(timeout);
timeout = setTimeout(function() {
p = $(this).scrollTop();
if(p <= 500)
{
if (t <= p) {
//下滚
scrollSpan = p-t;
blurValue = blurValue + (scrollSpan*0.03);
scaleValuex=scaleValuex+(scrollSpan * 0.0005);
scaleValuey= scaleValuey+(scrollSpan * 0.0005);
var scale = scaleValuex+ ','+scaleValuey+','+scaleValuez;
opacityValue = opacityValue - (scrollSpan * 0.005);
//视频变模糊
$('#vedioCover').css('-webkit-filter','blur('+blurValue +'px)');
//视屏放大效果
$('#vedioCover').css('transform','translate3d(0px, 0px, 0px) scale3d('+scale+')');
//视频变模糊
$('#mobileCover').css('-webkit-filter','blur('+blurValue +'px)');
//视屏放大效果
$('#mobileCover').css('transform','translate3d(0px, 0px, 0px) scale3d('+scale+')');
//$('#hotelSearchSection').css('opacity',opacityValue).css('-webkit-filter','blur('+blurValue +'px)');
}
else {//上滚
scrollSpan = t-p;
blurValue = blurValue - (scrollSpan*0.03);
scaleValuex=scaleValuex-(scrollSpan * 0.0005);
scaleValuey= scaleValuey-(scrollSpan * 0.0005);
var scale = scaleValuex+ ','+scaleValuey+','+scaleValuez;
opacityValue = opacityValue + (scrollSpan * 0.005);
$('#vedioCover').css('-webkit-filter','blur('+blurValue +'px)');
$('#vedioCover').css('transform','translate3d(0px, 0px, 0px) scale3d('+scale+')');
$('#mobileCover').css('-webkit-filter','blur('+blurValue +'px)');
$('#mobileCover').css('transform','translate3d(0px, 0px, 0px) scale3d('+scale+')');
// $('#hotelSearchSection').css('opacity',opacityValue).css('-webkit-filter','blur('+blurValue +'px)');
}
setTimeout(function () {
t = p;
}, 0);
}
}, 10);
})
10 回答11.1k 阅读
6 回答3k 阅读
5 回答4.8k 阅读✓ 已解决
4 回答3.1k 阅读✓ 已解决
2 回答2.6k 阅读✓ 已解决
3 回答5.1k 阅读✓ 已解决
5 回答1.9k 阅读
不用css3 js控制zoom也可以