效果

HTML代码

<!DOCTYPE html>
<html> <head>
<meta charset="UTF-8">
<title>jQuery+css3实现极具创意的罗盘旋转时钟效果源码</title>
<link rel="stylesheet" type="text/css" href="css/index.css" />
<script src="js/jquery.min.js" type="text/javascript" charset="utf-8"></script>
</head> <body>
<!--背景-->
<div class="clock-container">
<!--左边时间-->
<div class="clock-digital">
<div class="date"></div>
<div class="time"></div>
<div class="day"> </div>
</div>
<!--表盘-->
<div class="clock-analog">
<!--红线-->
<div class="spear"></div>
<!--时钟-->
<div class="hour"></div>
<!--分钟-->
<div class="minute"></div>
<!--秒钟-->
<div class="second"></div>
<!--表盘边框-->
<div class="dail"></div>
</div>
</div>
<script src="js/index.js" type="text/javascript" charset="utf-8"></script>
</body> </html>

css代码

*,
*:after,
*:before {
-webkit-box-sizing: border-box;
box-sizing: border-box;
} html {
overflow: hidden;
font-size: 16px;
} .clock-container {
position: absolute;
left: 50%;
top: 50%;
-webkit-transform: translate(-50%, -50%);
transform: translate(-50%, -50%);
width: 480px;
height: 480px;
border-radius: 50%;
overflow: hidden;
background: #111;
} .clock-container .spear {
position: absolute;
width: 220px;
background: red;
left: 50%;
top: 50%;
-webkit-transform: translateY(-50%);
transform: translateY(-50%);
z-index:;
-webkit-box-shadow: 0 3px 3px rgba(0, 0, 0, 0.4);
box-shadow: 0 3px 3px rgba(0, 0, 0, 0.4);
} .clock-container .spear:after {
content: '';
position: absolute;
border: 7px solid transparent;
border-right-color: red;
right:;
top: -7px;
} .clock-container .spear:before {
content: '';
position: absolute;
border: 7px solid transparent;
border-left-color: red;
left: 2px;
top: -7px;
} .clock-container .clock-analog {
width: 440px;
height: 440px;
border-radius: 50%;
margin: 20px;
background: #fff;
z-index:;
position: relative;
} .clock-container .clock-analog .hour,
.clock-container .clock-analog .minute,
.clock-container .clock-analog .second {
width: 50px;
height: 20px;
position: absolute;
left:;
top:;
right:;
bottom:;
margin: auto;
z-index:;
-webkit-transition: 0.2s 0.2s ease-in;
transition: 0.2s 0.2s ease-in;
-webkit-transform: rotate(0deg);
transform: rotate(0deg);
} .clock-container .clock-analog .hour span,
.clock-container .clock-analog .minute span,
.clock-container .clock-analog .second span {
position: absolute;
width: 50px;
height: 20px;
line-height: 20px;
text-align: center;
-webkit-transform-origin: 50%;
transform-origin: 50%;
z-index:;
} .clock-container .clock-analog .hour span:after,
.clock-container .clock-analog .minute span:after,
.clock-container .clock-analog .second span:after {
content: '';
width: 4px;
height: 1px;
background: #000;
position: absolute;
left: 130%;
top: -10%;
opacity: 0.3;
} .clock-container .clock-analog .hour span:nth-child(5n+2):after,
.clock-container .clock-analog .minute span:nth-child(5n+2):after,
.clock-container .clock-analog .second span:nth-child(5n+2):after {
width: 7px;
opacity:;
left: 110%;
} .clock-container .clock-analog .hour {
z-index:;
} .clock-container .clock-analog .hour span:after {
opacity:;
width: 4px;
height: 1px;
color: #666;
-webkit-transform: translate(5px, 12px);
transform: translate(5px, 12px);
} .clock-container .clock-analog .hour:after {
content: '';
background: #fff;
position: absolute;
left: 50%;
top: 50%;
-webkit-transform: translate(-50%, -50%);
transform: translate(-50%, -50%);
width: 250px;
height: 250px;
border-radius: 50%;
-webkit-box-shadow: 0 0 15px 2px rgba(0, 0, 0, 0.6) inset;
box-shadow: 0 0 15px 2px rgba(0, 0, 0, 0.6) inset;
} .clock-container .clock-analog .minute {
color: #fff;
} .clock-container .clock-analog .minute span:after {
background: #fff;
-webkit-transform: translate(10px, -7px) rotate(-9deg);
transform: translate(10px, -7px) rotate(-9deg);
} .clock-container .clock-analog .minute:after {
content: '';
background: #333;
position: absolute;
left: 50%;
top: 50%;
-webkit-transform: translate(-50%, -50%);
transform: translate(-50%, -50%);
width: 350px;
height: 350px;
border-radius: 50%;
-webkit-box-shadow: 0 0 25px 2px #000 inset;
box-shadow: 0 0 25px 2px #000 inset;
} .clock-container .clock-analog .second span:after {
-webkit-transform: translate(5px, -10px);
transform: translate(5px, -10px);
} .clock-container .clock-analog .dail {
width: 20px;
height: 20px;
position: absolute;
left:;
top:;
right:;
bottom:;
margin: auto;
z-index:;
} .clock-container .clock-analog .dail span {
width: 20px;
height: 20px;
line-height: 20px;
-webkit-transform-origin: 50%;
transform-origin: 50%;
text-indent: 1000px;
overflow: hidden;
position: absolute;
} .clock-container .clock-analog .dail span:after {
content: '';
position: absolute;
width: 4px;
height: 4px;
border-radius: 50%;
background-color: #7d7e7d;
*zoom:;
filter: progid:DXImageTransform.Microsoft.gradient(gradientType=1, startColorstr='#FF7D7E7D', endColorstr='#FF0E0E0E');
background-image: url("data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0idXRmLTgiPz4gPHN2ZyB2ZXJzaW9uPSIxLjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+PGRlZnM+PGxpbmVhckdyYWRpZW50IGlkPSJncmFkIiBncmFkaWVudFVuaXRzPSJvYmplY3RCb3VuZGluZ0JveCIgeDE9IjAuMCIgeTE9IjAuNSIgeDI9IjEuMCIgeTI9IjAuNSI+PHN0b3Agb2Zmc2V0PSIwJSIgc3RvcC1jb2xvcj0iIzdkN2U3ZCIvPjxzdG9wIG9mZnNldD0iMTAwJSIgc3RvcC1jb2xvcj0iIzBlMGUwZSIvPjwvbGluZWFyR3JhZGllbnQ+PC9kZWZzPjxyZWN0IHg9IjAiIHk9IjAiIHdpZHRoPSIxMDAlIiBoZWlnaHQ9IjEwMCUiIGZpbGw9InVybCgjZ3JhZCkiIC8+PC9zdmc+IA==");
background-size: 100%;
background-image: -webkit-gradient(linear, left top, right top, from(#7d7e7d), to(#0e0e0e));
background-image: linear-gradient(to right, #7d7e7d 0%, #0e0e0e 100%);
left: 50%;
top: 50%;
-webkit-transform: translate(-50%, -50%);
transform: translate(-50%, -50%);
} .clock-container .clock-analog .dail span:nth-child(5n+1):after {
width: 8px;
} .clock-container .clock-digital {
position: absolute;
z-index:;
height: 444px;
width: 224px;
background: #090909;
left: 18px;
top: 18px;
border-radius: 220px 0 0 220px;
-webkit-box-shadow: 5px 0 15px #000;
box-shadow: 5px 0 15px #000;
} .clock-container .clock-digital:after {
content: '';
position: absolute;
border: 15px solid white;
border-right: none;
height: 400px;
width: 200px;
border-radius: 220px 0 0 220px;
left: 25px;
top: 25px;
} .clock-container .clock-digital .time {
background: #111;
position: absolute;
right: 20px;
top: 50%;
-webkit-transform: translateY(-50%);
transform: translateY(-50%);
color: #fff;
border-radius: 50px;
font-size: 24px;
padding: 2px 20px;
-webkit-box-shadow: 0 0 15px #000 inset;
box-shadow: 0 0 15px #000 inset;
} .clock-container .clock-digital .day {
background: #111;
position: absolute;
right: 20px;
bottom: 100px;
color: #fff;
border-radius: 20px;
-webkit-box-shadow: 0 0 15px #000 inset;
box-shadow: 0 0 15px #000 inset;
padding: 2px 20px;
font-size: 16px;
} .clock-container .clock-digital .date {
background: #111;
position: absolute;
right: 20px;
top: 100px;
color: #fff;
border-radius: 20px;
font-size: 16px;
-webkit-box-shadow: 0 0 10px #000 inset;
box-shadow: 0 0 10px #000 inset;
padding: 2px 20px;
}

JavaScript代码

(function() {

    var months = ["January", "February", "March", "April", "May", "June",
"July", "August", "September", "October", "November", "December"
],
days = ['Sunday', 'Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday']; function getTime() { var date = new Date(),
second = date.getSeconds(),
minute = date.getMinutes(),
hour = date.getHours(),
time = date.toLocaleString('en-US', {
hour: 'numeric',
minute: 'numeric',
hour12: true
}),
day = date.getDay(),
month = date.getMonth(),
date = date.getDate() + ' . ' + months[month], ds = second * -6,
dm = minute * -6,
dh = hour * -30; $('.second').css('transform', 'rotate(' + ds + 'deg)');
$('.minute').css('transform', 'rotate(' + dm + 'deg)');
$('.hour').css('transform', 'rotate(' + dh + 'deg)'); $('.time').text(time);
$('.day').text(days[day]);
$('.date').text(date)
} function second(selector, size) {
for(var s = 0; s < 60; s++) {
$(selector).append('<span style="transform: rotate(' + 6 * s + 'deg) translateX(' + size + 'px)">' + s + '秒' + '</span>')
}
} function minute(selector, size) {
for(var s = 0; s < 60; s++) {
$(selector).append('<span style="transform: rotate(' + 6 * s + 'deg) translateX(' + size + 'px)">' + s + '分' + '</span>')
}
} function dail(selector, size) {
for(var s = 0; s < 60; s++) {
$(selector).append('<span style="transform: rotate(' + 6 * s + 'deg) translateX(' + size + 'px)">' + s + '</span>')
}
} second('.second', 195);
minute('.minute', 145);
dail('.dail', 230); for(var s = 1; s < 13; s++) {
$('.hour').append('<span style="transform: rotate(' + 30 * s + 'deg) translateX(100px)">' + s + '点' + '</span>')
} setInterval(getTime, 1000);
getTime(); }());

jQuery+css3实现极具创意的罗盘旋转时钟效果源码的更多相关文章

  1. 9款极具创意的HTML5/CSS3进度条动画(免积分下载)

    尊重原创,原文地址:http://www.cnblogs.com/html5tricks/p/3622918.html 免积分打包下载地址:http://download.csdn.net/detai ...

  2. 9款极具创意的HTML5/CSS3进度条动画

    今天我们要分享9款极具创意的HTML5/CSS3进度条动画,这些进度条也许可以帮你增强用户交互和提高用户体验,喜欢的朋友就收藏了吧. 1.HTML5/CSS3图片加载进度条 可切换多主题 今天要分享的 ...

  3. 分享9款极具创意的HTML5/CSS3进度条动画

    1.HTML5/CSS3图片加载进度条 可切换多主题 今天要分享的这款HTML5/CSS3进度条模拟了真实的图片加载场景,插件会默认去从服务器下载几张比较大的图片,然后让该进度条展现当前读取图片的进度 ...

  4. jquery省市区三级联动(数据来源国家统计局官网)内附源码下载

    很久很久没有写博了. 今天更新了项目的省市区三级联动数据,更新后最新的海南三沙都有,分享给所有需要的小伙伴们... JQUERY + JSON,无数据库,纯JS代码,无加密,无压缩,可直接使用在任何项 ...

  5. CorelDRAW极具创意的多边形工具

    这是一个简单的教程,它展示了使用三种基本的CorelDRAW工具打造的创意性成果:多边形工具.挑选工具和形状工具. CorelDRAW 可让您以非常直观的方式创建多边形.尽管多边形工具乍看起来并不像一 ...

  6. JQuery实现图片轮播效果源码

    ======================整体结构======================== <div class="banner"> <ul class ...

  7. jQuery+Ajax滚屏异步加载数据实现(附源码)

    一.CSS样式 body { font:12px/1.0em Microsoft Yahei; line-height:1.6em; background:#fff; line-height:1.2e ...

  8. 分享8款最新HTML5/CSS3功能插件及源码下载

    1.HTML5/CSS3鬼脸表情下拉菜单 超级可爱 这款HTML5/CSS3鬼脸表情下拉菜单真的很特别,虽然菜单的实现并没有利用复杂的HTML5/CSS3技术,但是创意的确不错. 在线演示 源码下载 ...

  9. 20+功能强大的jQuery/CSS3图片特效插件

    以下是分享的20几个不错的图片特效插件,基于jQuery和CSS3. 1.jQuery图片下滑切换播放效果 这是一款基于jQuery的焦点图插件,这款焦点图的特点是有向下滑动的动画效果,滑到底部时,有 ...

随机推荐

  1. TP5.1 首页路由

    把自带的return 删了

  2. 【python之路19】文件操作

    一.打开文件 文件句柄 = open('文件路径', '模式') 打开文件时,需要指定文件路径和以何等方式打开文件,打开后,即可获取该文件句柄,日后通过此文件句柄对该文件操作. 打开文件的模式有: r ...

  3. 从0开始学习 GitHub 系列之「02.加入 GitHub」

    转载地址: http://blog.csdn.net/googdev/article/details/52787586 看完昨天的文章「从0开始学习 GitHub 系列之「初识 GitHub」」估计不 ...

  4. Python运用于数据分析的简单教程

    Python运用于数据分析的简单教程 这篇文章主要介绍了Python运用于数据分析的简单教程,主要介绍了如何运用Python来进行数据导入.变化.统计和假设检验等基本的数据分析,需要的朋友可以参考下 ...

  5. 使用python爬去国家民政最新的省份代码的程序,requests,beautifulsoup,lxml

    使用的python3.6 民政网站,不同年份数据可能页面结构不一致,这点踩了很多坑,这也是代码越写越长的原因. 如果以后此段代码不可用,希望再仔细学习下 页面结构是否发生了变更. # -*- codi ...

  6. 注解2 --- 自定义 Annotation --- 技术搬运工(尚硅谷)

    定义新的 Annotation 类型使用 @interface 关键字 自定义注解自动继承了java.lang.annotation.Annotation接口 Annotation 的成员变量在 An ...

  7. JSP页面中验证码的调用方法

    步骤: 1.首先是要生成验证码 2.对验证码类进行调用:主要 实现的是  将验证码图片 输出到response.getOutputStream()这个输出流中 调用时,可以在页面调用,也可以在serv ...

  8. DirectX11笔记(五)--Direct3D渲染1--VERTICES AND INPUT LAYOUTS

    原文:DirectX11笔记(五)--Direct3D渲染1--VERTICES AND INPUT LAYOUTS 版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.c ...

  9. HTML5小知识汇总

    1.关于<!DOCTYPE HTML> H5只需要<!DOCTYPE HTML>这样简单的声明,不用之前一长串代码,因为H5不是基于SGML,所以不需要对DTD引用,但是需要D ...

  10. web服务器与tomcat

    web服务器与tomcat 服务器分类: 硬件服务器和软件服务器 web服务器: 提供资源供别人访问 web: 网页的意思,资源. web资源分类: 动态的web资源:内容有可能发生改变的 静态的we ...