JS实现钟表效果

JS实现钟表效果


通过new Date();获取实时时间然后通过css3的定位和旋转实现钟表效果




css代码:

	<style>
		.clock {
			position: relative;
			width: 400px;
			height: 400px;
			margin: 20px auto;
			border-radius: 50%;
			background: url(images/clock.png);
		}
		.clock div:nth-child(1), .clock div:nth-child(2), .clock div:nth-child(3), .clock div:nth-child(4) {
			position: absolute;
			-webkit-transform-origin: bottom;
		}
		.clock div:nth-child(1) {
			top: 45px;
			left: 197px;
			width: 4px;
			height: 160px;
			border-top-right-radius: 50px;
			background: #343339;
		}
		.clock div:nth-child(2) {
			top: 80px;
			left: 195px;
			width: 6px;
			height: 120px;
			border-top-right-radius: 10px;
			border-bottom-right-radius: 10px;
			background: #343332;
		}
		.clock div:nth-child(3) {
			top: 100px;
			left: 195px;
			width: 8px;
			height: 100px;
			border-top-right-radius: 10px;
			border-bottom-right-radius: 10px;
			background: #010001;
		}
		.clock div:nth-child(4) {
			top: 189px;
			left: 188px;
			width: 20px;
			height: 20px;
			border: 1px solid #fff;
			border-radius: 50%;
			background: rgba(237, 200, 45, 1);
		}
    </style>


html代码:

<div class="clock">
		<div id="sec"></div>
		<div id="min"></div>
		<div id="hour"></div>
		<div></div>
	</div>


js代码:

	<script>
		var hour = document.getElementById('hour');
		var min = document.getElementById('min');
		var sec = document.getElementById('sec');
		var timer = null;
		function sport (){
			var time = new Date();
			sec.style.webkitTransform = 'rotate(' + time.getSeconds() * 6 + 'deg)';
			min.style.webkitTransform = 'rotate(' + (time.getMinutes() + time.getSeconds() / 60) * 6 + 'deg)';
			hour.style.WebkitTransform = 'rotate(' + (time.getHours() % 12 + time.getMinutes() / 60 + time.getSeconds() / 3600) * 30 + 'deg)';
			console.log(sec.style.WebkitTransform);
		}sport ();
		setInterval(sport, 1000);
	</script>


  • 4
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值