css3翻牌翻数字的示例代码
发布时间:2020-02-07 15:16:40 作者:andy
我要评论
这篇文章主要介绍了css3翻牌翻数字的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
今天接到公司一任务,效果图如下:

没有具体说做什么效果,但是想着纯数字转换太简单了,然后就顺手做了一个翻牌的效果。

效果预览,新窗口打开:https://codepen.io/andy-js/pen/ExaGxaL
首先做一些页面布局:
<ul></ul>
body{background: #000;}
ul{
list-style: none;
margin:100px 0;
display: flex;
justify-content:center;
line-height: 56px;
height:56px;
font-size: 39.6px;
color: #FFFFFF;
transform-style:preserve-3d;
perspective:1000px;
}
li{
height:56px;
margin:0 10px;
background:none;
width:16px;
position: relative;
}
.num{
width:46px;
transform-style:preserve-3d;
perspective:1000px;
transform:rotateY(0deg);
transition: 1s all ease;
}
p{
height:56px;
width:46px;
text-align: center;
background: #EC2C5C;
border-radius: 2.57px;
position: absolute;
}
p:nth-child(2){
transform: scalex(-1) translateZ(-1px);
}
然后通过动态插入,模拟了这么一个效果
利用了transition来做的动画
利用transform:rotateY来做的翻转
在翻转之前先将另一个数字scalex左右镜像之后translateZ(-1px)移动到另一个数字的后面,这样翻转过来就能看到镜像的数字
不是很完善,还有很多可以改进的地方
全部代码如下:
<script>
var number=9999993,
numArr=addComma(number),
aNum=[],
oUl=document.getElementsByTagName('ul')[0];
for(let i=0;i<numArr.length;i++){
let li=document.createElement('li');
oUl.appendChild(li);
if(numArr[i]==',')
li.innerHTML=',';
else
li.innerHTML='<p>'+numArr[i]+'</p><p></p>',
li.className='num',
li.deg=0,
aNum.push(li);
};
setInterval(function(){
let changeNum=number+1+'';
let changeArr=addComma(changeNum),
difference=changeArr.length-numArr.length;
if(difference){
for(let i=0;i<difference;i++){
let li=document.createElement('li');
oUl.insertBefore(li,oUl.children[0]);
if(changeArr[i]==',')
li.innerHTML=',';
else
li.innerHTML='<p>'+changeArr[i]+'</p><p></p>',
li.className='num',
li.deg=0,
aNum.unshift(li);
};
};
number+='';
for(let i=changeNum.length-number.length;i<changeNum.length;i++){
if(changeNum[i]==number[i])continue;
let deg=aNum[i].deg;
aNum[i].deg=deg=deg+180;
let index=(deg/180)%2;
aNum[i].children[index].innerHTML=changeNum[i];
aNum[i].style.transform='rotateY('+deg+'deg)';
};
number=Number(changeNum);
numArr=changeArr;
},2000);
function addComma(num){ //每隔三位数加一个豆号
return (num || 0).toString().replace(/(\d)(?=(?:\d{3})+$)/g, '$1,');
};
</script>
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
相关文章
CS3的Grid网格布局是目前最强的二维布局系统,可以同时对列和行进行处理,将网页划分成一个个网格,可以任意组合不同的网格,做出各种各样的布局,本文介绍CSS3 最强二维布局系2025-02-27- 本文介绍了如何使用CSS3的transform属性和动画技巧实现波浪式图片墙,通过设置图片的垂直偏移量,并使用动画使其周期性地改变位置,可以创建出动态且具有波浪效果的图片墙,同2025-02-27
文章介绍了如何使用CSS3实现一个雷达探测扫描的效果,包括夜色背景、蜘蛛网盘、扫描体的转动效果、尾巴阴影以及被扫描到的光点,通过HTML和CSS的配合,实现了丰富的动画效果,2025-02-21- CSS3的Flexbox是一种强大的布局模式,通过设置display:flex可以轻松实现对齐、排列和分布网页元素,它解决了传统布局方法中的对齐、间距分配和自适应布局等问题,接下来通过本2025-02-19
本文给大家介绍css3 实现icon刷新转动效果,文章开头给大家介绍了webkit-transform、animation、@keyframes这三个属性,结合实例代码给大家介绍的非常详细,感兴趣的朋友一2025-02-19- CSS3过渡属性用于实现元素从一种样式平滑过渡到另一种样式,通过设置transition-property过渡属性、transition-duration过渡时长transition-timing-function过渡函数和trans2025-02-19
- 本文介绍了如何使用CSS3创建一个简单的动态旋转加载样式,通过定义一个带有类名“loader”的HTML元素,并使用CSS样式和@keyframes规则来实现旋转动画,你可以根据需要调整样式2025-02-19
- 这篇文章主要介绍了如何使用CSS3的transition属性实现平滑的过渡动画,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友一起看看吧2025-02-13
本文介绍了使用CSS3中的Flexbox和Grid布局实现等高元素布局的方法,通过简单的两列实现、每行放置3列以及全部代码的展示,展示了这两种布局方式的实现细节和效果,感兴趣的朋2025-02-11- CSS3和SVG的结合使用为网页设计带来了创新的动态视觉效果,本文通过一个圆形进度条的动画特效示例,展示了如何利用CSS3的动画功能和SVG的矢量图形能力来创建丰富的用户交互体2024-10-24






最新评论