本文目錄一覽:
- 1、如何使用JS實現一個簡易數碼時鐘
- 2、求一款js做的時間日曆控制項?
- 3、怎樣在jsp頁面中顯示日曆(高手幫下忙啦!很急)
- 4、用js在網頁上顯示當前日期和時間,並顯示是星期幾
- 5、js Canvas實現的日曆時鐘案例有哪些
如何使用JS實現一個簡易數碼時鐘
設計思路:
數碼時鐘即通過圖片數字來顯示當前時間,需要顯示的圖片的URL根據時間變化而變化。
a、獲取當前時間Date()並將當前時間信息轉換為一個6位的字元串;
b、根據時間字元串每個位置對應的數字來更改圖片的src的值,從而實現更換顯示圖片;
構建HTML基礎並添加樣式。
div id=”div1″
img src=’./數字時鐘(1)_files/0.jpg’
img src=’./數字時鐘(1)_files/0.jpg’
:
img src=’./數字時鐘(1)_files/0.jpg’
img src=’./數字時鐘(1)_files/0.jpg’
:
img src=’./數字時鐘(1)_files/0.jpg’
img src=’./數字時鐘(1)_files/0.jpg’
/div
style樣式
#div1{
width:50%;
margin:300px auto;
background:black;
}
獲取圖片元素以及當前時間:
var oDiv=document.getElementById(‘div1’);
var aImg=oDiv.getElementsByTagName(‘img’);
var oDate=new Date();
var str=oDate.getHours()+oDate.getMinutes()+oDate.getSeconds();
這裡出現兩個問題
1、oDate.getHours()返回的都是數字,這樣編寫為數字相加,而非字元串相加。
2、當獲取的值為一位數時,會造成字元串的個數少於6,不滿足初始設計要求。
解決以上兩個問題的代碼解決方案:
代碼
var oDiv=document.getElementById(‘div1’);
var aImg=oDiv.getElementsByTagName(‘img’);
var oDate=new Date();
function twoDigitsStr()
{
if(n10)
{return ‘0’+n;}
else
{return ”+n;}
}
var str=twoDigitsStr(oDate.getHours())+twoDigitsStr(oDate.getMinutes())+twoDigitsStr(oDate.getSeconds());
設置所有圖片的src值:
for(var i=0;iaImg.length;i++)
{
aImg[i].src=”./數字時鐘(1)_files/”+str.charAt(i)+”.jpg”;
}
通過setInterval()來實現每隔1秒進行重新獲取當前時間以及圖片src值:
代碼
var oDiv=document.getElementById(‘div1’);
var aImg=oDiv.getElementsByTagName(‘img’);
setInterval(function tick()
{
var oDate=new Date();
var str=twoDigitsStr(oDate.getHours())+twoDigitsStr(oDate.getMinutes())+twoDigitsStr(oDate.getSeconds());
for(var i=0;iaImg.length;i++)
{
aImg[i].src=”./數字時鐘(1)_files/”+str.charAt(i)+”.jpg”;
}
}
,1000);
但是還是有一個問題,網頁在打開的初始階段,顯示時間為00:00:00,這是因為定時器有個特性,當定時器被打開後,不會立刻執行裡面的函數,而是在1秒後執行。解決代碼:
var oDiv=document.getElementById(‘div1’);
var aImg=oDiv.getElementsByTagName(‘img’);
function tick()
{var oDate=new Date();
var str=twoDigitsStr(oDate.getHours())+twoDigitsStr(oDate.getMinutes())+twoDigitsStr(oDate.getSeconds());
for(var i=0;iaImg.length;i++)
{
aImg[i].src=”./數字時鐘(1)_files/”+str.charAt(i)+”.jpg”;
}
}
setInterval(tick,1000);
tick();
問題:代碼setInterval(tick,1000);中函數tick沒有帶括弧,那麼JS中函數帶括弧與不帶括弧有什麼區別?
完整的數碼時鐘製作JS代碼為:
function twoDigitsStr(n)
{
if(n10)
{return ‘0’+n;}
else
{return ”+n;}
}
window.onload=function()
{
var oDiv=document.getElementById(‘div1’);
var aImg=oDiv.getElementsByTagName(‘img’);
function tick()
{var oDate=new Date();
var str=twoDigitsStr(oDate.getHours())+twoDigitsStr(oDate.getMinutes())+twoDigitsStr(oDate.getSeconds());
for(var i=0;iaImg.length;i++)
{
aImg[i].src=”./數字時鐘(1)_files/”+str.charAt(i)+”.jpg”;
}
}
setInterval(tick,1000);
tick();
}
求一款js做的時間日曆控制項?
這是我找到的一個js做的日曆,不知道是不是你要的,裡面有包含時間,其實在日曆裡面加時間也是比較簡單的,只要調用DATE的方法就可以了,希望對你有用。下面是代碼段,效果圖附上。
html
head
SCRIPT LANGUAGE=”JavaScript” TYPE=”text/javascript”
//定義月曆函數
function calendar() {
var today = new Date(); //創建日期對象
year = today.getYear(); //讀取年份
thisDay = today.getDate(); //讀取當前日
//創建每月天數數組
var monthDays = new Array(31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31);
//如果是閏年,2月份的天數為29天
if (((year % 4 == 0) (year % 100 != 0)) || (year % 400 == 0)) monthDays[1] = 29;
daysOfCurrentMonth = monthDays[today.getMonth()]; //從每月天數數組中讀取當月的天數
firstDay = today;//複製日期對象
firstDay.setDate(1); //設置日期對象firstDay的日為1號
startDay = firstDay.getDay(); //確定當月第一天是星期幾
//定義周日和月份中文名數組
var dayNames = new Array(“星期日”,”星期一”,”星期二”,”星期三”,”星期四”,”星期五”,”星期六”);
var monthNames = new Array(“1月”,”2月”,”3月”,”4月”,”5月”,”6月”,”7月”,”8月”,”9月”,”10月”,”11月”,”12月”);
//創建日期對象
var newDate = new Date();
//創建表格
document.write(“TABLE BORDER=’0′ CELLSPACING=’0′ CELLPADDING=’2′ ALIGN=’CENTER’ BGCOLOR=’#0080FF'”)
document.write(“TRTDtable border=’0′ cellspacing=’1′ cellpadding=’2′ bgcolor=’#88FF99′”);
document.write(“TRth colspan=’7′ bgcolor=’#C8E3FF'”);
//顯示當前日期和周日
document.writeln(“FONT STYLE=’font-size:9pt;Color:#FF0000′” + newDate.getYear() + “年” + monthNames[newDate.getMonth()] + ” ” + newDate.getDate() + “日 ” + dayNames[newDate.getDay()] + “/FONT”);
//顯示月曆表頭
document.writeln(“/TH/TRTRTH BGCOLOR=’#0080FF’FONT STYLE=’font-size:9pt;Color:White’日/FONT/TH”);
document.writeln(“th bgcolor=’#0080FF’FONT STYLE=’font-size:9pt;Color:White’一/FONT/TH”);
document.writeln(“TH BGCOLOR=’#0080FF’FONT STYLE=’font-size:9pt;Color:White’二/FONT/TH”);
document.writeln(“TH BGCOLOR=’#0080FF’FONT STYLE=’font-size:9pt;Color:White’三/FONT/TH”);
document.writeln(“TH BGCOLOR=’#0080FF’FONT STYLE=’font-size:9pt;Color:White’四/FONT/TH”);
document.writeln(“TH BGCOLOR=’#0080FF’FONT STYLE=’font-size:9pt;Color:White’五/FONT/TH”);
document.writeln(“TH BGCOLOR=’#0080FF’FONT STYLE=’font-size:9pt;Color:White’六/FONT/TH”);
document.writeln(“/TRTR”);
//顯示每月前面的”空日”
column = 0;
for (i=0; istartDay; i++) {
document.writeln(” TDFONT STYLE=’font-size:9pt’ /FONT/TD”);
column++;
}
//如果是當前日就突出顯示(紅色),否則正常顯示(黑色)
for (i=1; i=daysOfCurrentMonth; i++) {
if (i == thisDay) {
document.writeln(“/TDTD ALIGN=’CENTER’FONT STYLE=’font-size:9pt;Color:#ff0000’B”)
}
else {
document.writeln(“/TDTD BGCOLOR=’#88FF99′ ALIGN=’CENTER’FONT STYLE=’font-size:9pt;font-family:Arial;font-weight:bold;Color:#000000′”);
}
document.writeln(i);
if (i == thisDay) document.writeln(“/FONT/TD”)
column++;
if (column == 7) {
document.writeln(“TR”);
column = 0;
}
}
document.writeln(“TRTD COLSPAN=’7′ ALIGN=’CENTER’ VALIGN=’TOP’ BGCOLOR=’#0080FF'”)
document.writeln(“FORM NAME=’time’ onSubmit=’0’FONT STYLE=’font-size:9pt;Color:#ffffff'”)
//顯示當前時間
document.writeln(“當前時間:INPUT TYPE=’Text’ NAME=’textbox’ ALIGN=’TOP’/FONT/TD/TR/TABLE”)
document.writeln(“/TD/TR/TABLE/FORM”);
}
/SCRIPT
SCRIPT LANGUAGE=”JavaScript”
//初始化控制變數
var timerID = null;
var timerRunning = false;
//定義時間顯示函數
function stoptime (){
if(timerRunning)
clearTimeout(timerID);
timerRunning = false;}
//定義顯示時間函數
function showtime () {
var newDate = new Date();
var hours = newDate.getHours();
var minutes = newDate.getMinutes();
var seconds = newDate.getSeconds()
var timeValue = ” ” + ((hours 12) ? hours -12 :hours)
timeValue += ((minutes 10) ? “:0” : “:”) + minutes
timeValue += ((seconds 10) ? “:0” : “:”) + seconds
timeValue += (hours = 12) ? ” 下午 ” : ” 上午 “
document.time.textbox.value = timeValue;
timerID = setTimeout(“showtime()”,1000);//設置超時,使時間動態顯示
timerRunning = true;}
//顯示當前時間
function starttime () {
stoptime();
showtime();}
/SCRIPT
/head
BODY onLoad=”starttime()” TEXT=”#000000″ TOPMARGIN=”0″
script language=”JavaScript” type=”text/javascript”
calendar(); //顯示月曆
/script
/BODY
/html
怎樣在jsp頁面中顯示日曆(高手幫下忙啦!很急)
我覺得這個頁面用js來完成最好,有現成的東西可以給你,你只需要自己進行修改就可以,至於js文件需要的話我可以發給你,或者直接在baidu google搜索js日曆就可以了
用js在網頁上顯示當前日期和時間,並顯示是星期幾
1、要獲得當前時間,我們可以使用Date方法,new一個Date對象。
2、然後調用這個對象的toLocaleTimeString方法,來獲取具體的時間
3、最後使用alert方法來彈出結果,來驗證一下是否正確
4、運行頁面,點擊按鈕,可以看到彈出一個確認框里,裡面顯示的時間就是當前時間了。
js Canvas實現的日曆時鐘案例有哪些
一、.獲取上下文對象
var cxt = document.getElementById(『元素名』).getContect(『2d』);
IE8或更早的瀏覽器不支持元素。
二、 drawClock() – 實現畫時鐘
1. clearRect() 清空給定矩形內的指定像素。
context.clearRect(x,y,width,height);
屬性 | 值
—–|————
x,y | 要清除的矩形左上角點的(x,y)坐標
width,height| 要清除的矩形寬度和高度,單位為像素12345
2.new Date() — 得到系統時間
var sec = now.getSeconds(); var min = now.getMinutes(); var hour = now.getHours(); 123
3.畫時鐘的形狀
cxt.beginPath(); cxt.lineWidth = 10; cxt.strokeStyle = “blue”; cxt.arc(550, 310, 300, 0, 360, false); cxt.closePath(); cxt.stroke(); 123456
beginPath()的作用是canvas的繪製方法,都會以上一次beginPath之後的所有路徑為基礎進行繪製。
closepath()是關閉路徑,而不是結束路徑,它會試圖從當前路徑的終點連一條路徑到七、起點,讓整個路徑閉合起來。
cxt.lineWidth() : 畫筆的寬度
cxt.strokeStyle() : 設置或返回用於筆觸的顏色、漸變或模式。
屬性值:color 指示繪圖筆觸顏色的 CSS 顏色值。默認值是 #000000。
gradient 用於填充繪圖的漸變對象(線性或放射性)
pattern 用於創建 pattern 筆觸的 pattern 對象
stroke ()繪製已定義的路徑
arc() 方法創建弧/曲線(用於創建圓或部分圓)。如需通過 arc() 來創建圓,請把起始角設置為 0,結束角設置為 2*Math.PI。
context.arc(x,y,r,sAngle,eAngle,counterclockwise);
參數
描述
x 圓的中心的 x 坐標。
y 圓的中心的 y 坐標。
r 圓的半徑。
sAngle 起始角,以弧度計。(弧的圓形的三點鐘位置是 0 度)。
eAngle 結束角,以弧度計。
counterclockwise 可選。規定應該逆時針還是順時針繪圖。False = 順時針,true = 逆時針。
4)drawScale — 自定義函數畫刻度
function drawScale(size, width, color, value, startx, starty, endx, endy){
for(var i = 0; i size; i++){
drawPointer(width, color, value, i, startx, starty, endx, endy);
} } 12345
5. 畫時鐘刻度依託點
function drawPointer(width, color, value, angle, startx, starty, endx, endy){
cxt.save(); //先保存當前畫布
cxt.lineWidth = width; //設置畫筆的寬度
cxt.strokeStyle = color; //設置畫筆的顏色
cxt.translate(550, 310); //重置異次元空間的原點坐標
cxt.rotate(value * angle * Math.PI / 180); //設置旋轉的角度,參數是弧度
cxt.beginPath();
cxt.moveTo(startx, starty);
cxt.lineTo(endx, endy);
cxt.closePath(); //先閉合路徑,再畫線
cxt.stroke(); //開始畫線
cxt.restore(); //將旋轉後的線段返回給畫布 } 12345678910111213
translate() 方法重新映射畫布上的 (0,0) 位置。
–
JS代碼如下:
//獲取上下文文檔對象 var clock = document.getElementById(‘clock’);
var cxt = clock.getContext(‘2d’);
//畫指針 function drawPointer(width, color, value, angle, startx, starty, endx, endy){
cxt.save(); //先保存當前畫布
cxt.lineWidth = width; //設置畫筆的寬度
cxt.strokeStyle = color; //設置畫筆的顏色
cxt.translate(550, 310); //重置異次元空間的原點坐標
cxt.rotate(value * angle * Math.PI / 180); //設置旋轉的角度,參數是弧度
cxt.beginPath();
cxt.moveTo(startx, starty);
cxt.lineTo(endx, endy);
cxt.closePath(); //先閉合路徑,再畫線
cxt.stroke(); //開始畫線
cxt.restore(); //將旋轉後的線段返回給畫布 }
//畫刻度 function drawScale(size, width, color, value, startx, starty, endx, endy){
for(var i = 0; i size; i++){
drawPointer(width, color, value, i, startx, starty, endx, endy);
}
}
//為錶盤的中心填充顏色 function drawFill(){
cxt.save();
cxt.beginPath();
cxt.arc(550, 310, 7, 0, 360, false);
cxt.closePath();
cxt.fillStyle = “red”;
cxt.fill();
cxt.restore();
}
//畫時鐘 function drawClock(){
cxt.clearRect(0, 0, 1350, 620); //清空整個畫布
var now = new Date(); //獲取系統時間,取出時,分,秒
var sec = now.getSeconds();
var min = now.getMinutes();
var hour = now.getHours();
min += sec / 60;
hour += min / 60;
if(hour 12) hour -= 12;
cxt.beginPath();
cxt.lineWidth = 10;
cxt.strokeStyle = “blue”;
cxt.arc(550, 310, 300, 0, 360, false);
cxt.closePath();
cxt.stroke();
drawScale(12, 7, “pink”, 30, 0, -280, 0, -260); //畫時刻度
drawScale(60, 5, “pink”, 6, 0, -280, 0, -270); //畫分刻度
drawPointer(7, “purple”, hour, 30, 0, 12, 0, -210); //畫時針
drawPointer(5, “yellow”, min, 6, 0, 15, 0, -240); //畫分針
drawPointer(4, “red”, sec, 6, 0, 17, 0, -250); //畫秒針
//細化秒針,為秒針加箭頭
drawPointer(3, “red”, sec, 6, -7, -235, 0, -255);
drawPointer(3, “red”, sec, 6, 7, -235, 0, -255);
drawFill();
}
drawClock();
setInterval(drawClock, 1000); //setInterval()方法中表示每隔1000ms,就執行drawClock一次 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071
原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/312503.html