本文实例为大家分享了vue实现抖音时间转盘的具体代码,供大家参考,具体内容如下
做了一个抖音时间转盘,还挺简单的,可能我做的很粗糙
用vue做的 才160行代码。
其实很简单 只是大部分人被这个圆给迷惑了
这个圆就是用简单css3就能做 通过rotate来修改计算就能展示出来了。
然后贴代码。
<template>
<div class="main">
<div class="timeBox">
<div class="yearBox box">{{year}}</div>
<div class="dayBox box" :style="'transform: rotate('+(360/day.length)*curDay+'deg)'">
<ul class="container">
<li
v-for="(v,i) in day"
:key="i"
:style="'transform: rotate('+(-360/day.length) * (i+1) +'deg);transform-origin: -100% 50% 0px;margin-left:150px;margin-top:90px'"
>{{v}}</li>
</ul>
</div>
<div class="hourBox box" :style="'transform: rotate('+(-360/hour.length)*curHour+'deg)'">
<ul class="container">
<li
v-for="(v,i) in hour"
:key="i"
:style="'transform: rotate('+(360/hour.length)*i+'deg);transform-origin: -200% 50% 0px;margin-left:300px;margin-top:190px'"
>{{v}}</li>
</ul>
</div>
<div class="minutesBox box" :style="'transform: rotate('+(-360/minutes.length)*curMin+'deg)'">
<ul class="container">
<li
v-for="(v,i) in minutes"
:key="i"
:style="'transform: rotate('+(360/minutes.length)*i+'deg);transform-origin: -300% 50% 0px;margin-left:450px;margin-top:290px'"
>{{v}}</li>
</ul>
</div>
<div class="secondBox" :style="'transform: rotate('+(-360/seconds.length)*curSec+'deg)'">
<ul class="container">
<li
v-for="(v,i) in seconds"
:key="i"
:style="'transform: rotate('+(360/seconds.length)*i+'deg);transform-origin: -400% 50% 0px;margin-left:600px;margin-top:390px'"
>{{v}}</li>
</ul>
</div>
</div>
</div>
</template>
<script>
export default {
data: function () {
return {
data: ['零', '壹', '贰', '叁', '肆', '伍', '陆', '柒', '捌', '玖', '拾', '佰', '仟', '万'],
hour: [],
curHour: 0,
day: [],
curDay: 0,
minutes: [],
curMin: 0,
seconds: [],
curSec: 0,
year: ''
}
},
created () {
this.dealData()
this.seconds = JSON.parse(JSON.stringify(this.minutes))
var sky = ['', '辛', '壬', '癸', '甲', '乙', '丙', '丁', '戊', '己', '庚']
var land = ['', '酉', '戌', '亥', '子', '丑', '寅', '卯', '辰', '巳', '午', '未', '申']
var one = new Date().getFullYear() % 10
var two = new Date().getFullYear() % 12
this.year = sky[one] + land[two]
setInterval(() => {
this.getTime()
}, 1000)
},
methods: {
dealData () { // 生成数据
// 星期
for (let i = 0; i < 7; i++) {
this.day.push('星期' + this.data[i + 1])
}
// 小时
for (let i = 0; i < 24; i++) {
if (i < 11) {
this.hour.push(this.data[i])
} else {
this.hour.push((parseInt(i / 10) > 1 "scss" scoped>
.box{
position: absolute;
transition: 1s;
}
.main{
width: 100%;
height: 100vh;
overflow: hidden;
background: #ccc;
}
.yearBox{
top: 50%;
left: 50%;
height: 40px;
width: 40px;
margin-top: -20px;
margin-left: -20px;
line-height: 40px;
text-align: center;
font-size: 18px;
}
.timeBox{
width: 800px;
height: 800px;
margin: 0 auto;
position: relative;
}
.dayBox {
width: 200px;
height: 200px;
top: 300px;
left: 300px;
}
.hourBox {
width: 400px;
height: 400px;
top: 200px;
left: 200px;
}
.minutesBox {
width: 600px;
height: 600px;
top: 100px;
left: 100px;
}
.secondBox {
width: 800px;
height: 800px;
top: 0;
left: 0;
position: absolute;
}
.container {
overflow:auto;
li {
width: 50px;
height: 20px;
font-size: 12px;
position: absolute;
}
}
</style>
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
标签:
vue,抖音,时间转盘
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
暂无“vue实现抖音时间转盘”评论...
更新动态
2025年11月05日
2025年11月05日
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]

