用css3写了个滚动特效,可以向左滚动、向右滚动,方向自由控制,没用JavaScript或者jQuery纯css3写的,鼠标悬停在上面时可以终止动画,纯css3滚动特效和JavaScript或者jQuery写的效果一样。熟悉css3的animation动画属性一下就很好理解原理,具体的请看效果和代码吧!点击我看演示(地址:http://tangjiusheng.com/e/demo/css3-rolled)
代码如下:
<!DOCTYPE html>
<html>
<head>
<meta name="baidu-site-verification" content="ZP6BgXCtjB" />
<meta http-equiv="Cache-Control" content="no-siteapp"/>
<meta http-equiv="Cache-Control" content="no-transform"/>
<meta name="applicable-device" content="pc">
<meta http-equiv="Content-Type" content="text/html; charset=gbk" />
<title>纯css3滚动特效代码</title>
<style type="text/css">
.rolled{
position:fixed;bottom:20%;z-index:9999999;
-webkit-animation:rolled 50s .2s ease both infinite;
-moz-animation:rolled 50s .2s ease both infinite;
-o-animation:rolled 50s .2s ease both infinite;
-ms-animation:rolled 50s .2s ease both infinite;
}
.rolled:hover{
-webkit-animation-play-state:paused;
-moz-animation-play-state:paused;
-o-animation-play-state:paused;
-ms-animation-play-state:paused;
}
/*滚动动画*/
@-webkit-keyframes rolled{
0%{right:-14%;}
50%{right:36%;}
80%{right:66%;}
100%{right:100%;}
}
@-moz-keyframes rolled{
0%{right:-14%;}
50%{right:36%;}
80%{right:66%;}
100%{right:100%;}
}
@-o-keyframes rolled{
0%{right:-14%;}
50%{right:36%;}
80%{right:66%;}
100%{right:100%;}
}
@-ms-keyframes rolled{
0%{right:-14%;}
50%{right:36%;}
80%{right:66%;}
100%{right:100%;}
}
@keyframes rolled{
0%{right:-14%;}
50%{right:36%;}
80%{right:66%;}
100%{right:100%;}
}
</style>
</head>
<body>
<!--向左重复滚动动画-->
<div class="rolled">
<a href="#"><img src="images/rolled.png"></a>
</div>
</body>
</html>
除注明外的文章,均为来源:汤久生博客,转载请保留本文地址!
原文地址:http://tangjiusheng.com/css3/101.html
tml页面设置动态金额滚动效果!
一开始加载页面,数字都会过渡滚动到具体数字上!
代码:
html:
css:
js:
者 | 大澈
大家好,我是大澈!
又是好久没更文了,前阵子驾着新车回了趟老家,很“幸运”的经历了平原县地震的余波。
回想当时,半夜凌晨,房屋晃动,如同身处过山车,一切都很不真实。虽然震感时间很短暂,但是现在依旧让我记忆犹新,人类在大自然面前真的是太渺小了,很多时候真的是力不从心。
所以,真心想和大家说一句,生活不易,及时行乐,珍惜身边人,且行且珍惜。
ONE
需求分析,问题描述
一、需求
一个可以滚动的菜单,为它添加一个可以下拉滚动的提示。要求滚动到菜单最底部时,隐藏下拉滚动的提示,否则让其一直显示。
二、问题
1、如何实现滚动条效果?
2、如何判断是否滚动到底部?
TWO
解决问题,答案速览
实现代码如下,复制粘贴即可直接使用。
代码中滚动条的实现使用了element的el-scrollbar组件。组件中包裹的第一个div,指的是需要滚动的视图。组件中包裹的第二个div,指的是下拉滚动提示的图标,这里根据需求进行设置,可以更换静态的或者那种闪烁跳跃的动态提示图标。
// 1、模版
<el-scrollbar max-height="calc(100vh - 84px)" @scroll="handleScroll" ref="myScrollbar">
<div class="sideBarIn"></div>
<div class="pcSign pcIcon" v-if="isShowIcon">
<img class="iconImg" src="../assets/images/common/xiaGery.png"></div>
</el-scrollbar>
// 2、逻辑
// 滚动条事件
const handleScroll=(val)=> {
// 防止Scrollbar实例为空
if (!myScrollbar.value) {
return
}
// 判断是否滚动到底部
let isScrollToEnd=Number(myScrollbar.value.wrapRef.scrollTop.toFixed(0))
+ Number(myScrollbar.value.wrapRef.clientHeight.toFixed(0))===Number(myScrollbar.value.wrapRef.scrollHeight.toFixed(0));
if (isScrollToEnd) {
// 滚动到底部的处理逻辑
isShowIcon.value=false
} else {
// 非滚动到底部的处理逻辑
isShowIcon.value=true
}
}
// 3、样式
.pcIcon {
width:100%;
height: 100px;
position: absolute;
bottom: -4px;
left: 0;
text-align: center;
line-height: 130px;
background: linear-gradient(to bottom, rgba(234, 234, 234, 0.5), rgba(234, 234, 234, 1));
.iconImg {
width: 20px;
height: 20px;
}
}
.pcSign{
display: block;
}
THREE
问题解析,知识总结
一、如何实现滚动条效果?
实现滚动条效果有两种实现方式:利用css的overflow: scroll属性、利用element的el-scrollbar组件。
1、overflow: scroll属性
在div元素上添加 overflow-y: scroll; css属性,就能显示出一个滚动条,如果不指定是x或y轴,则水平和垂直都会出现滚动条。
当然,前提是你需要指定div元素的高度或者最大高度。
2、el-scrollbar组件
一般在vue项目中,我们可直接使用element的el-scrollbar组件,因为官方为我们提供了许多API,以及各种适配优化。
el-scrollbar组件的属性如下:
el-scrollbar组件的事件如下:
el-scrollbar组件的实例属性如下:
二、如何判断是否滚动到底部?
这里判断是否滚动到底部的关键在于scrollTop+clientHeight是否等于scrollHeight的值。只有当滚动的距离+可视区域的高度,与scrollHeight相等时,才证明滚动条滚动到了底部。
同样的,如果scrollHeight与可视区域的高度直接就相等时,又说明元素不可以滚动,也就没有滚动条。这一点在有此需求时,可以进行实用。
元素的几个宽高属性释义如下:
- END -
*请认真填写需求信息,我们会在24小时内与您取得联系。