热门壁纸 “罗盘时钟”原生js 实现

  • Post author:
  • Post category:其他


在地铁站看到一款旁边的人在刷音,看到一款神奇的壁纸,非常炫酷,名曰 “罗盘时钟 ” 后来查了一下,叫八卦时钟、旋转时钟的说法也有,当然这不是重点,重点是这个效果是怎么实现的?故作此文:

整个的时钟代码详见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 版权协议,转载请附上原文出处链接和本声明。