簡易js網頁實時時鐘日曆,js電子時鐘代碼

本文目錄一覽:

如何使用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

相關推薦

  • 銀行資金管理系統總結

    銀行資金管理系統是銀行日常業務運營的核心支撐系統,主要負責處理銀行的資金流動、結算、清算等業務。本文將從功能特點、技術架構、安全性以及未來發展趨勢等多個方面對銀行資金管理系統進行詳…

    編程 2025-04-29
  • 如何查看Anaconda中Python路徑

    對Anaconda中Python路徑即conda環境的查看進行詳細的闡述。 一、使用命令行查看 1、在Windows系統中,可以使用命令提示符(cmd)或者Anaconda Pro…

    編程 2025-04-29
  • 如何修改mysql的埠號

    本文將介紹如何修改mysql的埠號,方便開發者根據實際需求配置對應埠號。 一、為什麼需要修改mysql埠號 默認情況下,mysql使用的埠號是3306。在某些情況下,我們需…

    編程 2025-04-29
  • 英語年齡用連字元號(Hyphenation for English Age)

    英語年齡通常使用連字元號表示,比如 “five-year-old boy”。本文將從多個方面探討英語年齡的連字元使用問題。 一、英語年齡的表達方式 英語中表…

    編程 2025-04-29
  • Idea新建文件夾沒有java class的解決方法

    如果你在Idea中新建了一個文件夾,卻沒有Java Class,應該如何解決呢?下面從多個方面來進行解答。 一、檢查Idea設置 首先,我們應該檢查Idea的設置是否正確。打開Id…

    編程 2025-04-29
  • 金額選擇性序列化

    本文將從多個方面對金額選擇性序列化進行詳細闡述,包括其定義、使用場景、實現方法等。 一、定義 金額選擇性序列化指根據傳入的金額值,選擇是否進行序列化,以達到減少數據傳輸的目的。在實…

    編程 2025-04-29
  • Python中引入上一級目錄中函數

    Python中經常需要調用其他文件夾中的模塊或函數,其中一個常見的操作是引入上一級目錄中的函數。在此,我們將從多個角度詳細解釋如何在Python中引入上一級目錄的函數。 一、加入環…

    編程 2025-04-29
  • Python列表中負數的個數

    Python列表是一個有序的集合,可以存儲多個不同類型的元素。而負數是指小於0的整數。在Python列表中,我們想要找到負數的個數,可以通過以下幾個方面進行實現。 一、使用循環遍歷…

    編程 2025-04-29
  • Python周杰倫代碼用法介紹

    本文將從多個方面對Python周杰倫代碼進行詳細的闡述。 一、代碼介紹 from urllib.request import urlopen from bs4 import Bea…

    編程 2025-04-29
  • Java JsonPath 效率優化指南

    本篇文章將深入探討Java JsonPath的效率問題,並提供一些優化方案。 一、JsonPath 簡介 JsonPath是一個可用於從JSON數據中獲取信息的庫。它提供了一種DS…

    編程 2025-04-29