在地铁站看到一款旁边的人在刷音,看到一款神奇的壁纸,非常炫酷,名曰 “罗盘时钟 ” 后来查了一下,叫八卦时钟、旋转时钟的说法也有,当然这不是重点,重点是这个效果是怎么实现的?故作此文:
    整个的时钟代码详见Github :
    
    
     https://github.com/zhangtsh5/Rotating-Clock
    
   
    
    
    总体思路
   
首先肯定要把所有会出现的日期都放在页面上,然后经过某种变换,变成圆形的状态,利用js实现动态根据实时的时间进行旋转,css中提供了一个属性可以完成这种页面的变化,transform,因此可以大概设计出大体的主函数框架:
//时钟页面
let clock;
window.onload = function () {
    init();
    // 每隔100ms获得 当前时间
    setInterval(function () {
        runTime();
    }, 100);
    // 旋转之前定位到当前时间
    locateCurrent();
    // 3秒后变成旋转样式
    setTimeout(function () {
        toRotate();
    }, 3000);
}
    
    
    函数实现
   
    那么接下来要做的就是完善每一个函数的具体功能
    
    init:页面初始化函数,就是将那些所有会出现的时间日期名词平铺在页面上
   
// 初始化函数
function init() {
    clock = document.getElementById('clock');
    // 生成标签 存放文字展示
    for (let i = 0; i < timeTextSet.length; i++) {
        for (let j = 0; j < timeTextSet[i][0].length; j++) {
            let temp = createLabel(timeTextSet[i][0][j]);
            clock.appendChild(temp);
            // 将生成的标签存放在数组list中
            timeTextSet[i][1].push(temp);
        }
    }
}
 
版权声明:本文为qq_34123985原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
