javascript实现超酷的“网页时钟

原创 2007年10月03日 18:51:00

SCRIPT language=JavaScript>
!--
dCol='yellow'; //
定义日历颜色

fCol='#ff0000'; //
定义1-1212个数的颜色
sCol='#00ff00'; //
定义秒针颜色
mCol='#0000ff'; //
定义分针颜色
hCol='#ff0000'; //
定义时针颜色
ClockHeight=40; //
定义时钟的高度
ClockWidth=40; //
定义时钟的宽度
ClockFromMouseY=0; //
定义时钟的中心距鼠标的相对垂直距离
ClockFromMouseX=100; //
定义时钟中心距鼠标的相对水平距离
//
以上颜色值你要据你页面的背景颜色进行修改!注意不要你页面的背景色一致哦。
d=new Array("
星期日","星期一","星期二","星期三","星期四","星期五","星期六");
m=new Array("
一月","二月","三月","四月","五月","六月","七月","八月","九月
",
"
十月","十一月","十二月"); //以上是给定星期和月份的取值范围

date=new Date();
day=date.getDate(); //
取得当前日期命令
year=date.getYear(); //
取得当前年份命令
if (year
2000) year=year+1900;
TodaysDate="
"+m[date.getMonth()]+" "+day+"
"+d[date.getDay()]+" "+year;
D=TodaysDate.split(''); //
显示"某年某月某日
"
H='...';
H=H.split('');
M='....';
M=M.split('');
S='.....';
S=S.split(''); //
使秒、分、时针反向相应的位置

Face='1 2 3 4 5 6 7 8 9 10 11 12';
font='Arial';
size=1; //
定义秒、分、时针及1-12等字符的宋体、大小(最好匆改动哦)
speed=0.8; //
定义一旦鼠标位置发生变化时所有相关字符跟随至前面指定的鼠标的相对位置的速度,
能看到各字符的轨迹,值可在0.1-1.0之间改动(值最小为0.1时跟随过来的速度最慢,值为1.0时跟随速度最快且与轨迹显示)
ns=(document.layers);
ie=(document.all); //
说明在NSIE两种不同浏览器里都适用

//以下的大段语句定义了NSIE浏览器各自如何控制并完成时间和旋转的日历跟随鼠标转的
Face=Face.split(' ');
n=Face.length;
a=size*10;
ymouse=0;
xmouse=0;
scrll=0;
props="
font face="+font+" size="+size+" color="+fCol+">";
props2="
font face="+font+" size="+size+" color="+dCol+">";
Split=360/n;
Dsplit=360/D.length;
HandHeight=ClockHeight/4.5
HandWidth=ClockWidth/4.5
HandY=-7;
HandX=-2.5;
scrll=0;
step=0.06;
currStep=0;
y=new Array();x=new Array();Y=new Array();X=new Array();
for (i=0; i
n; i++){y[i]=0;x[i]=0;Y[i]=0;X[i]=0}
Dy=new Array();Dx=new Array();DY=new Array();DX=new Array();
for (i=0; i
D.length; i++){Dy[i]=0;Dx[i]=0;DY[i]=0;DX[i]=0}

if (ns){
for (i=0; i
D.length; i++)
document.write('
layer name="nsDate'+i+'" top=0 left=0 height='+a+' width='+a+'>center>'+props2+D[i]+'/font>/center>
/layer>');
for (i=0; i
n; i++)
document.write('
layer name="nsFace'+i+'" top=0 left=0 height='+a+' width='+a+'>center>'+props+Face[i]+'/font>/center>
/layer>');
for (i=0; i
S.length; i++)
document.write('
layer name=nsSeconds'+i+' top=0 left=0 width=15
height=15>
font face=Arial size=3 color='+sCol+'>center>b>'+S[i]+'/b>/center>/font>
/layer>');
for (i=0; i
M.length; i++)
document.write('
layer name=nsMinutes'+i+' top=0 left=0 width=15
height=15>
font face=Arial size=3 color='+mCol+'>center>b>'+M[i]+'/b>/center>/font>
/layer>');
for (i=0; i
H.length; i++)
document.write('
layer name=nsHours'+i+' top=0 left=0 width=15
height=15>
font face=Arial size=3 color='+hCol+'>center>b>'+H[i]+'/b>/center>/font>
/layer>');
}

if (ie){
document.write('
div id="Od" style="position:absolute;top:0px;left:0px">
div style="position:relative">');
for (i=0; i
D.length; i++)
document.write('
div id="ieDate" style="position:absolute;top:0px;left:0;height:'+a+';width:'+a+';text-align:center">'+props2+D[i]+'/font>
/div>');
document.write('
/div>
/div>');
document.write('
div id="Of" style="position:absolute;top:0px;left:0px">
div style="position:relative">');
for (i=0; i
n; i++)
document.write('
div id="ieFace" style="position:absolute;top:0px;left:0;height:'+a+';width:'+a+';text-align:center">'+props+Face[i]+'/font>
/div>');
document.write('
/div>
/div>');
document.write('
div id="Oh" style="position:absolute;top:0px;left:0px">
div style="position:relative">');
for (i=0; i
H.length; i++)
document.write('
div id="ieHours" style="position:absolute;width:16px;
height:16px;font-family:Arial;font-size:16px;color:'+hCol+';text-align:center;font-weight:bold">'+H[i]+'
/div>');
document.write('
/div>
/div>');
document.write('
div id="Om" style="position:absolute;top:0px;left:0px">
div style="position:relative">');
for (i=0; i
M.length; i++)
document.write('
div id="ieMinutes" style="position:absolute;width:16px;
height:16px;font-family:Arial;font-size:16px;color:'+mCol+';text-align:center;font-weight:bold">'+M[i]+'
/div>');
document.write('
/div>
/div>')
document.write('
div id="Os" style="position:absolute;top:0px;left:0px">
div style="position:relative">');
for (i=0; i
S.length; i++)
document.write('
div id="ieSeconds" style="position:absolute;width:16px;
height:16px;font-family:Arial;font-size:16px;color:'+sCol+';text-align:center;font-weight:bold">'+S[i]+'
/div>');
document.write('
/div>
/div>')
}
(ns)?window.captureEvents(Event.MOUSEMOVE):0;
function Mouse(evnt){
ymouse = (ns)?evnt.pageY+ClockFromMouseY-(window.pageYOffset):
event.y+ClockFromMouseY;
xmouse = (ns)?evnt.pageX+ClockFromMouseX:event.x+ClockFromMouseX;
}
(ns)?window.onMouseMove=Mouse:document.onmousemove=Mouse;
function ClockAndAssign(){
time = new Date ();
secs = time.getSeconds();
sec = -1.57 + Math.PI * secs/30;
mins = time.getMinutes();
min = -1.57 + Math.PI * mins/30;
hr = time.getHours();
hrs = -1.575 + Math.PI * hr/6+Math.PI*parseInt(time.getMinutes())/360;
if (ie){
Od.style.top=window.document.body.scrollTop;
Of.style.top=window.document.body.scrollTop;
Oh.style.top=window.document.body.scrollTop;
Om.style.top=window.document.body.scrollTop;
Os.style.top=window.document.body.scrollTop;
}
for (i=0; i
n; i++){
var F=(ns)?document.layers['nsFace'+i]:ieFace[i].style;
F.top=y[i] + ClockHeight*Math.sin(-1.0471 + i*Split*Math.PI/180)+scrll;
F.left=x[i] + ClockWidth*Math.cos(-1.0471 + i*Split*Math.PI/180);
}
for (i=0; i
H.length; i++){
var HL=(ns)?document.layers['nsHours'+i]:ieHours[i].style;
HL.top=y[i]+HandY+(i*HandHeight)*Math.sin(hrs)+scrll;
HL.left=x[i]+HandX+(i*HandWidth)*Math.cos(hrs);
}
for (i=0; i
M.length; i++){
var ML=(ns)?document.layers['nsMinutes'+i]:ieMinutes[i].style;
ML.top=y[i]+HandY+(i*HandHeight)*Math.sin(min)+scrll;
ML.left=x[i]+HandX+(i*HandWidth)*Math.cos(min);
}
for (i=0; i
S.length; i++){
var SL=(ns)?document.layers['nsSeconds'+i]:ieSeconds[i].style;
SL.top=y[i]+HandY+(i*HandHeight)*Math.sin(sec)+scrll;
SL.left=x[i]+HandX+(i*HandWidth)*Math.cos(sec);
}
for (i=0; i
D.length; i++){
var DL=(ns)?document.layers['nsDate'+i]:ieDate[i].style;
DL.top=Dy[i] + ClockHeight*1.5*Math.sin(currStep+i*Dsplit*Math.PI/180)+scrll;
DL.left=Dx[i] + ClockWidth*1.5*Math.cos(currStep+i*Dsplit*Math.PI/180);
}
currStep-=step;
}
function Delay(){
scrll=(ns)?window.pageYOffset:0;
Dy[0]=Math.round(DY[0]+=((ymouse)-DY[0])*speed);
Dx[0]=Math.round(DX[0]+=((xmouse)-DX[0])*speed);
for (i=1; i
D.length; i++){
Dy[i]=Math.round(DY[i]+=(Dy[i-1]-DY[i])*speed);
Dx[i]=Math.round(DX[i]+=(Dx[i-1]-DX[i])*speed);
}
y[0]=Math.round(Y[0]+=((ymouse)-Y[0])*speed);
x[0]=Math.round(X[0]+=((xmouse)-X[0])*speed);
for (i=1; i
n; i++){
y[i]=Math.round(Y[i]+=(y[i-1]-Y[i])*speed);
x[i]=Math.round(X[i]+=(x[i-1]-X[i])*speed);
}
ClockAndAssign();
setTimeout('Delay()',20);
}
if (ns||ie)window.onload=Delay;
//-->
/SCRIPT>

 

ECharts显示24小时时间数据的一种办法

ECharts3是一个超好用的图表库,在App中,我也让团队放弃原生组件,直接使用ECharts3. 我用ECharts主要是按天显示采集的时间序列数据,并且需要固定展示24小时的数据。 ...
  • yin138
  • yin138
  • 2016年12月18日 21:59
  • 11769

用 Canvas 绘制实时时钟

之前就看过关于 Canvas 的基础,但是还没上过战场实时过呢,今天就来练练手,画一个实时时钟吧~其实这个特别简单,稍微有点耐心都能完成~话不多少,还是喜欢直接上代码:  test.html 代码如...

reactjs+echarts实现绘图

echarts和reactjs实现简单绘图

javaScript实现自动时钟

定时函数 当前时间为:              //定时函数 //时间间隔函数 function show(){ //拿到系统时间对象 var date = new Date(); //获...

用JavaScript实现超酷的“网页时钟”

各位各位,大家好哇!都见识过网页上不少种类的日历和时钟吧!   今天给各位介绍的这个“跟着鼠标跑的时钟和日历”极COOL的,准保你没见过!   只须将如下的JavaScript代码插入到你页面html...
  • marixh
  • marixh
  • 2012年02月21日 19:11
  • 254

JS实现超酷时钟

这里分析一个带年月日、时分秒、星期数的时钟的制作过程,方法有点怪异,但是功能是OK的,主要是布局有点小问题。 首先来看看布局,时钟上的所有字都由图片构成,然后简易排下版,就跳过布局吧! ...

javascript框架echarts插件实现超酷人立方效果图

最近由于项目需求,需要做一个类似人立方效果的网络关系效果,在查询许多文档后,发现百度出echarts开源组件非常的适合,而且加载速度很棒,echarts图形主要是使用html5的新特性的做的,使用到了...

使用Javascript实现超酷tooltip

  • 2009年10月25日 20:36
  • 18KB
  • 下载

JavaScript实现超酷拖拽式列表

  • 2010年09月30日 14:40
  • 11KB
  • 下载

一个超酷的数码时钟(走秒的)

一个超酷的数码时钟(走秒的)
  • AmberWu
  • AmberWu
  • 2017年05月26日 20:34
  • 272
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:javascript实现超酷的“网页时钟
举报原因:
原因补充:

(最多只允许输入30个字)