vue2实现简易时钟效果
更新时间:2022年08月30日 11:46:42 作者:蜂巢糖FCT
这篇文章主要为大家详细介绍了vue2实现简易时钟效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
本文实例为大家分享了vue2实现简易时钟效果的具体代码,供大家参考,具体内容如下
1.vue2+纯css实现
预览效果:
2.代码如下:
<template> <div class="main"> <div class="time"> <div class="hour_wrap"> <div class="hour_item" :style="{transform:'translate(-50%,-50%)'+'rotate('+30*(index+1)+'deg)'}" v-for="(item,index) in 12" :key="index"> {{index+1}} <div class="ke"></div> </div> </div> <div class="minute_wrap"> <div class="minute_item" :style="{transform:'translate(-50%,-50%)'+'rotate('+6*(index+1)+'deg)'}" v-for=" (item,index) in 60" :key="index"> <div class="ke"></div> </div> </div> <div class="hour_hand" :style="{transform:'translate(-50%,-100%)'+'rotate('+30*hour+'deg)'}"></div> <div class="minute_hand" :style="{transform:'translate(-50%,-100%)'+'rotate('+6*minute+'deg)'}"></div> <div class="second_hand" :style="{transform:'translate(-50%,-100%)'+'rotate('+6*second+'deg)'}"></div> </div> </div> </template> <script> export default { data(){ return{ interval:{}, date:'', hour:0, minute:0, second:0, } }, mounted(){ this.interval = setInterval(()=>{ this.date = this.getDate(); this.hour = this.date.toString().split(' ')[1].split(':')[0]; this.minute = this.date.toString().split(' ')[1].split(':')[1]; this.second = this.date.toString().split(' ')[1].split(':')[2]; },1000); }, beforeDestroy(){ clearInterval(this.interval); }, methods:{ getDate(time,format){ var tf = function (i) { return (i < 10 ? '0' : '') + i }; var now = time?new Date(time):new Date(); var year = now.getFullYear(); var month = now.getMonth() + 1; var date = now.getDate(); var hour = now.getHours(); var minute = now.getMinutes(); var second = now.getSeconds(); if(format=='yyyy-mm-dd HH:mm:ss'){ return year + "-" + tf(month) + "-" + tf(date)+' '+hour+':'+tf(minute)+':'+tf(second); }else{ return year + "/" + tf(month) + "/" + tf(date)+' '+hour+':'+tf(minute)+':'+tf(second); } } } } </script> <style scoped lang="less"> .time{ border-radius:50%; width: 140px; height: 140px; border: 1px solid #000; position: relative; .hour_wrap{ width: 100%; height: 100%; position: absolute; left: 0; top: 0; z-index: 3; .hour_item{ position: absolute; top: 50%; left: 50%; height: 100%; width: 12px; font-size: 12px; text-align: center; transform-origin: 6px 70px; //transform: translate(-50%,-50%); .ke{ width: 3px; height: 8px; background-color: #000; margin: 0 auto; } } } .minute_wrap{ width: 100%; height: 100%; position: absolute; left: 0; top: 0; z-index: 2; .minute_item{ position: absolute; top: 50%; left: 50%; height: 100%; width: 10px; font-size: 12px; text-align: center; transform-origin: 5px 70px; //transform: translate(-50%,-50%); .ke{ width: 2px; height: 4px; background-color: #000; margin: 0 auto; margin-top: 10px; } } } .hour_hand{ width: 3px; height: 30px; background-color: #000; position: absolute; top: 50%; left: 50%; transform-origin: 1.5px 30px; } .minute_hand{ width: 2px; height: 50px; background-color: #000; position: absolute; top: 50%; left: 50%; transform-origin: 1px 50px; } .second_hand{ width: 1px; height: 60px; background-color: #000; position: absolute; top: 50%; left: 50%; transform-origin: 0.5px 60px; } } </style>
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
相关文章
超详细动手搭建一个VuePress 站点及开启PWA与自动部署的方法
这篇文章主要介绍了超详细动手搭建一个VuePress 站点及开启PWA与自动部署的方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧2019-01-01ant design vue 清空upload组件图片缓存的问题
这篇文章主要介绍了ant design vue 清空upload组件图片缓存的问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教2022-10-10element-ui动态添加表单项并实现事件触发验证代码示例
这篇文章主要给大家介绍了关于element-ui动态添加表单项并实现事件触发验证的相关资料,其实就是利用了vue的v-for循环渲染,通过添加数组实现动态添加表单项,需要的朋友可以参考下2023-12-12Vue表单绑定的实例代码(单选按钮,选择框(单选时,多选时,用 v-for 渲染的动态选项)
本文通过实例代码给大家介绍了Vue表单绑定(单选按钮,选择框(单选时,多选时,用 v-for 渲染的动态选项)的相关知识,非常不错,具有一定的参考借鉴价值 ,需要的朋友可以参考下2019-05-05
最新评论