首页 > 其他分享 >日常总结:Vue写一个炫酷的时钟插件

日常总结:Vue写一个炫酷的时钟插件

时间:2022-12-19 14:07:09浏览次数:49  
标签:index 插件 Vue clock transform flip rotateX 炫酷 webkit


效果图

日常总结:Vue写一个炫酷的时钟插件_ide

代码奉上:

<template>
<div class="clock">
<div class="flip">
<div class="digital front" :data-number="nextTimes[0]"></div>
<div class="digital back" :data-number="nowTimes[0]"></div>
</div>
<div class="flip">
<div class="digital front" :data-number="nextTimes[1]"></div>
<div class="digital back" :data-number="nowTimes[1]"></div>
</div>
<em class="divider">:</em>
<div class="flip">
<div class="digital front" :data-number="nextTimes[2]"></div>
<div class="digital back" :data-number="nowTimes[2]"></div>
</div>
<div class="flip">
<div class="digital front" :data-number="nextTimes[3]"></div>
<div class="digital back" :data-number="nowTimes[3]"></div>
</div>
<em class="divider">:</em>
<div class="flip">
<div class="digital front" :data-number="nextTimes[4]"></div>
<div class="digital back" :data-number="nowTimes[4]"></div>
</div>
<div class="flip">
<div class="digital front" :data-number="nextTimes[5]"></div>
<div class="digital back" :data-number="nowTimes[5]"></div>
</div>
</div>
</template>

<script>
export default {
name: "ClockData",
data () {
return {
duration: 650,
nowTimes: [],
nextTimes: [],
timer: {},
}
},
mounted() {
this.initDate();
this.timer = setInterval(() => {
this.updateTime();
}, 1000)
},
methods: {
initDate() {
let now = new Date();
this.nowTimes = this.getTimeFromDate(new Date(now.getTime() - 1000));
this.nextTimes = this.getTimeFromDate(now);
},
updateTime() {
let now = new Date();
let nowTimes = this.getTimeFromDate(new Date(now.getTime() - 1000));
let nextTimes = this.getTimeFromDate(now);;
for (let i = 0; i < 6; i++) {
if (nowTimes[i] !== nextTimes[i]) {
this.setSpin(i, nowTimes[i], nextTimes[i]);
}
}
},
setSpin(index, nowTime, nextTime) {
let nodes = document.querySelectorAll(".flip");
nodes[index].classList.add('running');
this.nowTimes.splice(index, 1, nowTime);
this.nextTimes.splice(index, 1, nextTime);
setTimeout(() => {
nodes[index].classList.remove('running');
this.nowTimes.splice(index, 1, nextTime);
}, this.duration)
},
getTimeFromDate(date) {
let numTime = [];
let timeStr = date
.toTimeString()
.slice(0, 8)
.split(":")
.join("");
for (let i = 0; i < timeStr.length; i++) {
numTime.push(parseInt(timeStr[i]));
}
return numTime;
}
},
destroyed() {
// 销毁定时器
clearInterval(this.timer);
}
}
</script>

<style scoped>
.clock {
display: flex;
}
.clock .divider {
font-size: 66px;
line-height: 102px;
font-style: normal;
}
.clock .flip {
position: relative;
width: 60px;
height: 100px;
margin: 2px;
font-size: 66px;
line-height: 100px;
text-align: center;
background: white;
border: 1px solid black;
border-radius: 12px;
}
.clock .flip .digital::before, .clock .flip .digital::after {
position: absolute;
content: attr(data-number);
left: 0;
right: 0;
color: white;
background: black;
overflow: hidden;
-webkit-perspective: 160px;
perspective: 160px;
}
.clock .flip .digital::before {
top: 0;
bottom: 50%;
border-bottom: 1px solid #666;
border-radius: 10px 10px 0 0;
}
.clock .flip .digital::after {
top: 50%;
bottom: 0;
line-height: 0;
border-radius: 0 0 10px 10px;
}
.clock .flip .back::before,
.clock .flip .front::after {
z-index: 1;
}
.clock .flip .back::after {
z-index: 2;
}
.clock .flip .front::before {
z-index: 3;
}
.clock .flip .back::after {
-webkit-transform-origin: center top;
transform-origin: center top;
-webkit-transform: rotateX(0.5turn);
transform: rotateX(0.5turn);
}
.clock .flip.running .front::before {
-webkit-transform-origin: center bottom;
transform-origin: center bottom;
-webkit-animation: frontFlipDown 0.6s ease-in-out;
animation: frontFlipDown 0.6s ease-in-out;
-webkit-backface-visibility: hidden;
backface-visibility: hidden;
}
.clock .flip.running .back::after {
-webkit-animation: backFlipDown 0.6s ease-in-out;
animation: backFlipDown 0.6s ease-in-out;
}
@-webkit-keyframes frontFlipDown {
to {
-webkit-transform: rotateX(0.5turn);
transform: rotateX(0.5turn);
}
}
@keyframes frontFlipDown {
to {
-webkit-transform: rotateX(0.5turn);
transform: rotateX(0.5turn);
}
}
@-webkit-keyframes backFlipDown {
to {
-webkit-transform: rotateX(0);
transform: rotateX(0);
}
}
@keyframes backFlipDown {
to {
-webkit-transform: rotateX(0);
transform: rotateX(0);
}
}
</style>

如果对大家有帮助请点个赞,谢谢!


标签:index,插件,Vue,clock,transform,flip,rotateX,炫酷,webkit
From: https://blog.51cto.com/luckyqilin/5952242

相关文章

  • 日常总结:Vue实现一个炫酷的代码瀑布流背景
    先看一下效果:代码奉上:<template><canvasid="canvas"/></template><script>exportdefault{name:"BackCanvas",props:{height:{......
  • vim插件配置
    配置的比较简单,主要有三个功能:背景主题,目录树和代码补全(c++,python)先安装vim-plug,用来管理插件 https://github.com/junegunn/vim-plug先创建路径~/.vim/autoload然后将......
  • vue基础 B站课程
     反转字符串:<template><div><!--先照抄,之后再自己写。多写。把vue的课程全学出来。。。。。职业:1学好本专业学技术2跨专业考研考公3.公务员教师......
  • vuejs实现文件下载的三种方式
    第一种方式是前端创建超链接,通过a标签的链接向后端服务发get请求,接收后端的文件流,非常简单:<a:href='"/路径"'>下载模板</a>另一种情况是创建div标签,动态创建a标签:<div......
  • Vue.$nextTick的原理是什么-vue面试进阶
    原理性的东西就会文字较多,请耐下心来,细细品味Vue中DOM更新机制当你气势汹汹地使用Vue大展宏图的时候,突然发现,咦,我明明对这个数据进行更改了,但是当我获取它的时候怎么是上......
  • 面试官:vue2和vue3的区别有哪些?
    一、Vue3与Vue2区别详述1.生命周期对于生命周期来说,整体上变化不大,只是大部分生命周期钩子名称上+“on”,功能上是类似的。不过有一点需要注意,Vue3在组合式API(Comp......
  • 必会vue面试题(附答案)
    vue初始化页面闪动问题使用vue开发时,在vue初始化之前,由于div是不归vue管的,所以我们写的代码在还没有解析的情况下会容易出现花屏现象,看到类似于{{message}}的字样,虽然一般......
  • 前端一面必会vue面试题(边面边更)
    为什么要使用异步组件节省打包出的结果,异步组件分开打包,采用jsonp的方式进行加载,有效解决文件过大的问题。核心就是包组件定义变成一个函数,依赖import()语法,可以实现文......
  • 说说你对Vue的keep-alive的理解
    什么是keep-alive在平常开发中,有部分组件没有必要多次初始化,这时,我们需要将组件进行持久化,使组件的状态维持不变,在下一次展示时,也不会进行重新初始化组件。也就是说,keep......
  • 说说Vue响应式系统中的Watcher和Dep的关系-面试进阶
    引言在这里我先提出两个问题(文章末尾会进行解答):在Vue的数据响应系统中,Dep和Watcher各自分担什么任务?Vue的数据响应系统的核心是Object.defineproperty一定是最好的吗?有......