利用css+原生js制作简单的钟表。效果如下所示

实现该效果,分三大块:html、javascript、css

html部分html部分比较简单,定义一个clock的div,内部有原点、时分秒针、日期以及时间,至于钟表上的刻度、数字等元素,因为量比较多,采用jvascript生成

时钟

css部分开始代码之前,有一些css的属性需要了解,比如定位(position),边框圆角(border-radius),变换(transform)等

position属性

position属性规定元素的定位类型,有五个值:absolute、fixed、relative、static、inherit,默认为static,即没有定位,元素按正常文档流显示;这里主要用到的是absolute和relative

absulte值,将元素设置成绝对定位,相对于static定位意外的第一个上级元素进行定位,位置可以通过'left'、'top'、'right'、'bottom'属性进行定位;如果上级元素都是static定位,则相对于body元素的位置进行定位

本例中,设定最外层的div clock为relative,所有下级元素均设定为absolute绝对定位,然后通过设置left、top等属性的值,确定其相对于clock的位置。

border-radius属性border-radius属性向元素添加圆角边框,可以设置四个圆角的大小,本例中使用该属性将clock元素设置成一个圆

此处写了一个示例:4个div元素,宽高都是100px,border-radius不同时的效果:

transform属性

transform属性向元素应用2D或3D旋转,该属性允许我们对元素进行旋转、缩放、移动、或倾斜。本例中时针、分针、秒针、刻度等均用transform属性设置旋转;另外,transform-origin属性可以设置元素的基点位置

css部分的代码

/* 全局 */

*{

margin:0;

padding:0;

}

.clock{

width:400px;

height:400px;

border:10px solid #333;

box-shadow: 0px 0px 20px 3px #444 inset;

border-radius:210px;

position:relative;

margin:5px auto;

z-index:10;

background-color:#f6f6f6;

}

/* 时钟数字 */

.clock-num{

width:40px;

height:40px;

font-size:22px;

text-align:center;

line-height:40px;

position:absolute;

z-index:8;

color:#555;

font-family:fantasy, 'Trebuchet MS';

}

.em_num{

font-size:28px;

}

/* 指针 */

.clock-line{

position:absolute;

z-index:20;

}

.hour-line{width:100px;

height:4px;

top:198px;

left:200px;

background-color:#000;

border-radius:2px;

transform-origin:0 50%;

box-shadow:1px -3px 8px 3px #aaa;

}

.minute-line{

width:130px;

height:2px;

top:199px;

left:190px;

background-color:#000;

transform-origin:7.692% 50%;

box-shadow:1px -3px 8px 1px #aaa;

}

.second-line{

width:170px;

height:1px;

top:199.5px;

left:180px;

background-color:#f60;

transform-origin:11.765% 50%;

box-shadow:1px -3px 7px 1px #bbb;

}

/* 原点 */

.origin{

width:20px;

height:20px;

border-radius:10px;

background-color:#000;

position:absolute;

top:190px;

left:190px;

z-index:14;

}

/* 日期 时间 */

.date-info{

width:160px;

height:28px;

line-height:28px;

text-align:center;

position:absolute;

top:230px;

left:120px;

z-index:11;

color:#555;

font-weight:bold;

font-family:'微软雅黑';

}

.time-info{

width:92px;

height:30px;

line-height:30px;

text-align:center;

position:absolute;

top:270px;

left:154px;

z-index:11;

background-color:#555;

padding:0;

box-shadow:0px 0px 9px 2px #222 inset;

}

.time{

width:30px;

height:30px;

text-align:center;

float:left;

color:#fff;

font-weight:bold;

}

#minute-time{

border-left:1px solid #fff;

border-right:1px solid #fff;

}

/* 刻度 */

.clock-scale{

width:195px;

height:2px;

transform-origin:0% 50%;

z-index:7;

position:absolute;

top:199px;

left:200px;

}

.scale-show{

width:12px;

height:2px;

background-color:#555;

float:left;

}

.scale-hidden{

width:183px;

height:2px;

float:left;

}

javascript部分

js部分没什么好说的,简单的dom操作,setInterval函数每隔一秒执行一次,修改指针的角度和显示的时间即可。代码如下

(function(){

window.οnlοad=initNumXY(200, 160, 40,40);

var hour_line = document.getElementById("hour-line");

var minute_line = document.getElementById("minute-line");

var second_line = document.getElementById("second-line");

var date_info = document.getElementById("date-info");

var week_day = [

'星期日', '星期一', '星期二', '星期三', '星期四', '星期五', '星期六'

];

var hour_time = document.getElementById("hour-time");

var minute_time = document.getElementById("minute-time");

var second_time = document.getElementById("second-time");

function setTime(){

var this_day = new Date();

var hour = (this_day.getHours() >= 12) ?

(this_day.getHours() - 12) : this_day.getHours();

var minute = this_day.getMinutes();

var second = this_day.getSeconds();

var hour_rotate = (hour*30-90) + (Math.floor(minute / 12) * 6);

var year = this_day.getFullYear();

var month = ((this_day.getMonth() + 1) < 10 ) ?

"0"+(this_day.getMonth() + 1) : (this_day.getMonth() + 1);

var date = (this_day.getDate() < 10 ) ?

"0"+this_day.getDate() : this_day.getDate();

var day = this_day.getDay();

hour_line.style.transform = 'rotate(' + hour_rotate + 'deg)';

minute_line.style.transform = 'rotate(' + (minute*6 - 90) + 'deg)';

second_line.style.transform = 'rotate(' + (second*6 - 90)+'deg)';

date_info.innerHTML =

year + "-" + month + "-" + date + " " + week_day[day];

hour_time.innerHTML = (this_day.getHours() < 10) ?

"0" + this_day.getHours() : this_day.getHours();

minute_time.innerHTML = (this_day.getMinutes() < 10) ?

"0" + this_day.getMinutes() : this_day.getMinutes();

second_time.innerHTML = (this_day.getSeconds() < 10) ?

"0" + this_day.getSeconds():this_day.getSeconds();

}

setInterval(setTime, 1000);

function initNumXY(R, r, w, h){

var numXY = [

{

"left" : R + 0.5 * r - 0.5 * w,

"top" : R - 0.5 * r * 1.73205 - 0.5 * h

},

{

"left" : R + 0.5 * r * 1.73205 - 0.5 * w,

"top" : R - 0.5 * r - 0.5 * h

},

{

"left" : R + r - 0.5 * w,

"top" : R - 0.5 * h

},

{

"left" : R + 0.5 * r * 1.73205 - 0.5 * w,

"top" : R + 0.5 * r - 0.5 * h

},

{

"left" : R + 0.5 * r - 0.5 * w,

"top" : R + 0.5 * r * 1.732 - 0.5 * h

},

{

"left" : R - 0.5 * w,

"top" : R + r - 0.5 * h

},

{

"left" : R - 0.5 * r - 0.5 * w,

"top" : R + 0.5 * r * 1.732 - 0.5 * h

},

{

"left" : R - 0.5 * r * 1.73205 - 0.5 * w,

"top" : R + 0.5 * r - 0.5 * h

},

{

"left" : R - r - 0.5 * w,

"top" : R - 0.5 * h

},

{

"left" : R - 0.5 * r * 1.73205 - 0.5 * w,

"top" : R - 0.5 * r - 0.5 * h

},

{

"left" : R - 0.5 * r - 0.5 * w,

"top": R - 0.5 * r * 1.73205 - 0.5 * h

},

{

"left" : R - 0.5 * w,

"top" : R - r - 0.5 * h

}

];

var clock = document.getElementById("clock");

for(var i = 1; i <= 12; i++){

if(i%3 == 0) {

clock.innerHTML += "

"+i+"

";

} else {

clock.innerHTML += "

" + i + "

";

}

}

var clock_num = document.getElementsByClassName("clock-num");

for(var i = 0; i < clock_num.length; i++) {

clock_num[i].style.left = numXY[i].left + 'px';

clock_num[i].style.top = numXY[i].top + 'px';

}

for(var i = 0; i < 60; i++) {

clock.innerHTML += "

" +

"

"

"

";

}

var scale = document.getElementsByClassName("clock-scale");

for(var i = 0; i < scale.length; i++) {

scale[i].style.transform="rotate(" + (i * 6 - 90) + "deg)";

}

}

})();

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

css画钟表_利用css+原生js制作简单的钟表相关推荐

  1. 利用HTML5+CSS3+JS实现简单的钟表

    HTML5+CSS3+JS实现动态时钟 利用HTML5+CSS3+JS实现简单的钟表,仅供参考学习 效果图: 在线效果预览 思路: 1. 先定义一个类名为timepiece的圆表表盘 HTML: &l ...

  2. 原生JS制作简单的漂浮广告

    漂浮广告的原理:用通俗一点的话来说,漂浮广告就是一个在不断改变自身位置的div(当然亦可以是其他),并且在遇到界面的边界时改变当前运动的方向: **第一步:**制作一个能够移动的div,并给各项参数赋 ...

  3. php简单网页制作代码,用HTML和CSS以及JS制作简单的网页菜单界面的代码

    这篇文章主要介绍了使用HTML+CSS+JS制作简单的网页菜单界面,这个ABROAD项目所使用的JavaScript部分代码非常简单,需要的朋友可以参考下 写ABROAD项目用到了标签这个东东,其实标 ...

  4. css表格排序,纯CSS实现表格排序-利用CSS 变量和Flexbox

    1.引子 今天闲逛知名前端资讯站Front-End Front,发现一个比较有意思的效果,给大家分享下,希望可以对大家有所启发. 纯CSS实现表格排序 心急的同学,先看效果,我放在codepen上. ...

  5. [css] CSS画一个三角形,CSS绘制空心三角形

    1.不同理解的边框 <div class="border"></div> .border {width: 50px;height: 50px;border: ...

  6. 原生JS制作自动+手动轮播图,附带二级分类菜单

    原生JS制作自动+手动轮播图,附带二级分类菜单 包含以下功能: 1.鼠标移开自动轮播 2.鼠标移入停止自动轮播 3.点击左右按钮可手动切换图片 4.点击索引小圆点可手动切换图片 5.鼠标移入一级菜单展 ...

  7. 原生JS实现简单放大镜效果

    [前言] 本文介绍下原生JS实现简单图片放大镜效果 [主体] 时间问题,直接上源码 <!DOCTYPE html> <html> <head><meta ch ...

  8. 深圳java培训:使用原生JS重构简单的音乐播放器

    深圳java培训:使用原生JS重构简单的音乐播放器 上次,我们使用Jquery开发了一款简单的音乐播放器(如下图), 后来学生希望能够用原生的JS重构一次, 那么,下面就来看看如何使用原生的JS重构吧 ...

  9. 如何用原生JS制作图片时钟

    程序设计之道无远弗届,御晨风而返.---- 杰佛瑞 · 詹姆士 今天分享一个小demo,如何用原生JS制作图片时钟,话不多说上代码. html[外链图片转存失败(img-mD0n42FM-156223 ...

最新文章

  1. Ios中checkBox
  2. Tcpdump配合Tcpreplay回放实现网络探测
  3. 如何启用nodejs request模块的调试模式
  4. SqlHelper改造版本
  5. Ubuntu禁用网卡步骤(重启依然生效)
  6. mac 下载appium
  7. 根据城市的三字代码查询经纬度_中国国内机场三字码及经纬度
  8. android 智能手机usb驱动程序,华为手机usb驱动下载
  9. 计算机绘出一条虚线算法步骤,计算机图形学 第二章 基本图形生成算法.ppt
  10. 【C++】图片转byte
  11. 如何使用PS将图片中的类千图网的字眼去掉
  12. 给服务器下载补丁及安装补丁
  13. STM32F030的低功耗案例(RTC闹钟中断定时唤醒喂狗+按键外部中断唤醒)
  14. 数据库的基本概念-基础(课堂笔记)
  15. 免费地图下载流量如何领取?
  16. Deepin/Uos中添加PPA时显示找不到命令
  17. 项目管理手记 28 ERP项目的高层支持要知行合一
  18. office全套教程(2003~2016)
  19. 微信小程序 open-type=contact
  20. 百度推广有哪些技巧方法?在品牌宣传上百度推广有哪些技巧方法

热门文章

  1. docker安装zookeeper,以及zk可视化界面介绍
  2. 阅读笔记-原生家庭·如何修补自己的性格缺陷
  3. 工作经验是积累总结出来的
  4. 免费的 PPT 模版资源
  5. 适合穷人挣钱最快的方法
  6. 南京邮电大学实验报告3.3
  7. “上链”究竟上的什么
  8. python之最大公约数
  9. 守护“城市生命线” | 地空智能带您走进数字孪生地下管网
  10. ubuntu配置IP地址,网关,DNS和路由