js圖片時鐘實例,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 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

一個JS的簡單時鐘程序

該時鐘顯示的內容格式是:“今天是****年**月**日 上午00:00:00”,程序如下:

script language=”javascript”

now = new Date()

hour = now.getHours()

if (hour 12) {

document.write(“今天是” + now.toLocaleString())

} else if (hour 18){

document.write(“今天是” + now.toLocaleString())

} else if (hour = 18){

document.write(“今天是” + now.toLocaleString())

}

/script

把上述程序複製到“ html ”格式的文件里並保存,然後打開即可看到效果。

javascript,實現一個時鐘,頁面顯示當前時間包括年月日時 分 秒 並設定一個時間點,當該

html

head

titleTime/title

/head

body

div id=”time”/div

div id=”alert”/div

/body

script type=”text/javascript” charset=”utf-8″ async defer

var time = document.getElementById(“time”);

showTime();

function showTime() {

// To get the date time

var date = new Date();

var year = date.getYear() + 1900;

var month = date.getMonth() + 1;

var day = date.getDate();

var hour = date.getHours();

var min = date.getMinutes();

var sec = date.getSeconds();

var date_time = year + “-” + month + “-” + day + ” ” + hour + “:” + min + “:” + sec;

time.innerHTML = date_time;

// when the time is equal your condition, show the special words.

if(date_time == “2014-6-25 11:45:20”) {

document.getElementById(“alert”).innerHTML = “It’s time to display your words here.”;

}

}

// set the interval time

setInterval(showTime, 1000);

/script

/html

js用圖片做時間和日期

js:script type=”text/javascript”

function toDou(n){//將十以內的數字轉換成兩位

if(n10){

return ‘0’+n;

}else{

return ”+n;

}

}

function tick(){//獲取當前時間,並轉換為字符串,循環獲取字符串並改變節點圖片路徑

var oDate = new Date();

var str = toDou(oDate.getHours())+toDou(oDate.getMinutes())+toDou(oDate.getSeconds());

var oImg = document.getElementsByTagName(‘img’);

for(var i = 0;ioImg.length;i++){//charAt()兼容性要比str[i]好

oImg[i].src = ‘img/’+str.charAt(i)+’.png’;

}

}

window.onload = function(){//setInterval(function(){},毫秒);每隔指定的時間就執行一次函數

tick();

setInterval(tick, 1000);

};

/script

原創文章,作者:簡單一點,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/128053.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
簡單一點的頭像簡單一點
上一篇 2024-10-03 23:24
下一篇 2024-10-03 23:24

相關推薦

  • JS Proxy(array)用法介紹

    JS Proxy(array)可以說是ES6中非常重要的一個特性,它可以代理一個數組,監聽數據變化並進行攔截、處理。在實際開發中,使用Proxy(array)可以方便地實現數據的監…

    編程 2025-04-29
  • 用Python繪製酷炫圖片

    在本篇文章中,我們將展示如何使用Python繪製酷炫的圖片。 一、安裝Python繪圖庫 在使用Python繪製圖片之前,我們需要先安裝Python繪圖庫。Python有很多繪圖庫…

    編程 2025-04-29
  • Python生成隨機數的應用和實例

    本文將向您介紹如何使用Python生成50個60到100之間的隨機數,並將列舉使用隨機數的幾個實際應用場景。 一、生成隨機數的代碼示例 import random # 生成50個6…

    編程 2025-04-29
  • 使用axios獲取返回圖片

    使用axios獲取返回圖片是Web開發中很常見的需求。本文將介紹如何使用axios獲取返回圖片,並從多個方面進行詳細闡述。 一、安裝axios 使用axios獲取返回圖片前,首先需…

    編程 2025-04-29
  • Python 圖片轉表格

    本文將詳細介紹如何使用Python將圖片轉為表格。大家平時在處理一些資料的時候難免會遇到圖片轉表格的需求。比如從PDF文檔中提取表格等場景。當然,這個功能也可以通過手動複製、粘貼,…

    編程 2025-04-29
  • Python緩存圖片的處理方式

    本文將從多個方面詳細闡述Python緩存圖片的處理方式,包括緩存原理、緩存框架、緩存策略、緩存更新和緩存清除等方面。 一、緩存原理 緩存是一種提高應用程序性能的技術,在網絡應用中流…

    編程 2025-04-29
  • Python如何抓取圖片數據

    Python是一門強大的編程語言,能夠輕鬆地進行各種數據抓取與處理。抓取圖片數據是一個非常常見的需求。在這篇文章中,我們將從多個方面介紹Python如何抓取圖片數據。 一、使用ur…

    編程 2025-04-29
  • 解析js base64並轉成unit

    本文將從多個方面詳細介紹js中如何解析base64編碼並轉成unit格式。 一、base64編碼解析 在JavaScript中解析base64編碼可以使用atob()函數,它會將b…

    編程 2025-04-29
  • Node.js使用Body-Parser處理HTTP POST請求時,特殊字符無法返回的解決方法

    本文將解決Node.js使用Body-Parser處理HTTP POST請求時,特殊字符無法返回的問題。同時,給出一些相關示例代碼,以幫助讀者更好的理解並處理這個問題。 一、問題解…

    編程 2025-04-29
  • Python利用Image加圖片的方法

    在Python中,利用Image庫可以快速處理圖片,並加入需要的圖片,本文將從多個方面詳細闡述這個操作。 一、Image庫的安裝和基礎操作 首先,我們需要在Python中安裝Ima…

    編程 2025-04-28

發表回復

登錄後才能評論