同步服务器端读秒
服务器端传来时间戳,在客户端实现与服务器时间相同的时间读秒,需要引入jquery.min.js,下面直接上代码nbsp;html><br>
<br>
<br>
<meta>
<br>
<title></title>
<br>
<br>
<br>
<div></div>
<br>
<br>
<script></script><br>
<script><br />
$(function(){<br />
time('w','1483199990');<br />
}<br />
);<br />
<br />
/**<br />
* 读秒函数,此函数会阻塞在其后的函数,SO 这个函数需要放到所有函数最后(此函数最大动态显示到了一个月,会根据润平年判断这个月的天数)<br />
* @id {string} 存放时间的div的id名<br />
* @t {int} timestamp 服务器端传过来的时间戳,如果没有传则自动获取浏览器端的时间<br />
*/<br />
function time(id,t){<br />
setTimeout('time("'+id+','+t+'");',1000);<br />
<br />
var dm=date('i',t);<br />
var ds=date('s',t);<br />
var dh=date('H',t);<br />
var dd=date('d',t);<br />
var dmm=date('m',t);<br />
var dy=date('Y',t);<br />
<br />
<br />
var k= $('#'+id).html();<br />
if(k.length==0){<br />
$('#'+id).html('<span id="y">'+dy+'-<span id="mm">'+dmm+'-<span id="d">'+dd+' <span id="h">'+dh+':<span id="m">'+dm+':<span id="s">'+ds+'');<br />
}<br />
<br />
var s=$('#s').html();<br />
var m=$('#m').html();<br />
var h=$('#h').html();<br />
var d=$('#d').html();<br />
var mm=$('#mm').html();<br />
var y=$('#y').html();<br />
if(s.length==0){<br />
s=0;<br />
}<br />
<br />
if(parseInt(s)==60){<br />
s=0;<br />
rm=parseInt(m)+parseInt(1);<br />
if(rm==60){<br />
rm=0;<br />
rh=parseInt(h)+parseInt(1);<br />
if(rh==24){<br />
rh=0;<br />
rd=parseInt(d)+parseInt(1);<br />
//润平年选择<br />
var big=Array(1,3,5,7,8,10,12);<br />
var small=Array(4,6,9,11);<br />
if(IsPinYer(y)){ //2月29天<br />
if(mm==2){ //2月<br />
if(rd==30){<br />
rd=1;<br />
rmm=parseInt(mm)+parseInt(1);<br />
ry=parseInt(y);<br />
}else{<br />
rmm=parseInt(mm);<br />
ry=parseInt(y);<br />
}<br />
}<br />
if(InArray(mm,big)){<br />
if(rd==32){<br />
rd=1;<br />
rmm=parseInt(mm)+parseInt(1);<br />
if(rmm==13){ //跨年<br />
rmm=1;<br />
ry=parseInt(y)+parseInt(1);<br />
}else {<br />
ry = parseInt(y);<br />
}<br />
}else{<br />
rmm=parseInt(mm);<br />
ry=parseInt(y);<br />
}<br />
}<br />
if(InArray(mm,small)){<br />
if(rd==31){<br />
rd=1;<br />
rmm=parseInt(mm)+parseInt(1);<br />
ry=parseInt(y);<br />
}else{<br />
rmm=parseInt(mm);<br />
ry=parseInt(y);<br />
}<br />
}<br />
}else{ //2月28天<br />
if(mm==2){ //2月<br />
if(rd==29){<br />
rd=1;<br />
rmm=parseInt(mm)+parseInt(1);<br />
ry=parseInt(y);<br />
}else{<br />
rmm=parseInt(mm);<br />
ry=parseInt(y);<br />
}<br />
}<br />
if(InArray(mm,big)){<br />
if(rd==32){<br />
rd=1;<br />
rmm=parseInt(mm)+parseInt(1);<br />
if(rmm==13){ //跨年<br />
rmm=1;<br />
ry=parseInt(y)+parseInt(1);<br />
}else {<br />
ry = parseInt(y);<br />
}<br />
}else{<br />
rmm=parseInt(mm);<br />
ry=parseInt(y);<br />
}<br />
}<br />
if(InArray(mm,small)){<br />
if(rd==31){<br />
rd=1;<br />
rmm=parseInt(mm)+parseInt(1);<br />
ry=parseInt(y);<br />
}else{<br />
rmm=parseInt(mm);<br />
ry=parseInt(y);<br />
}<br />
}<br />
}<br />
}else{<br />
rd=parseInt(d);<br />
rmm=parseInt(mm);<br />
ry=parseInt(y);<br />
}<br />
}else{<br />
rh=parseInt(h);<br />
rd=parseInt(d);<br />
rmm=parseInt(mm);<br />
ry=parseInt(y);<br />
}<br />
}else{<br />
var rm=parseInt(m);<br />
var rh=parseInt(h);<br />
var rd=parseInt(d);<br />
var rmm=parseInt(mm);<br />
var ry=parseInt(y);<br />
}<br />
<br />
var v=parseInt(s)+parseInt(1);<br />
$('#'+id).html('<span id="y">'+ry+'-<span id="mm">'+rmm+'-<span id="d">'+rd+' <span id="h">'+rh+':<span id="m">'+rm+':<span id="s">'+v+'');<br />
}<br />
<br />
<br />
<br />
function InArray(str,arr){ //判断str是否在arr这个数组中存在<br />
for(var i=0;i<arr.length;i++){<br />
if(arr[i]==str){<br />
return true;<br />
}<br />
}<br />
return false;<br />
}<br />
<br />
<br />
<br />
/**<br />
* 和PHP一样的时间戳格式化函数<br />
* @param {string} format 格式<br />
* @param {int} timestamp 要格式化的时间 默认为当前时间<br />
* @return {string} 格式化的时间字符串<br />
*/<br />
function date(format, timestamp){<br />
var a, jsdate=((timestamp) ? new Date(timestamp*1000) : new Date());<br />
var pad = function(n, c){<br />
if((n = n + "").length < c){<br />
return new Array(++c - n.length).join("0") + n;<br />
} else {<br />
return n;<br />
}<br />
};<br />
var txt_weekdays = ["Sunday", "Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturday"];<br />
var txt_ordin = {1:"st", 2:"nd", 3:"rd", 21:"st", 22:"nd", 23:"rd", 31:"st"};<br />
var txt_months = ["", "January", "February", "March", "April", "May", "June", "July", "August", "September", "October", "November", "December"];<br />
var f = {<br />
// Day<br />
d: function(){return pad(f.j(), 2)},<br />
D: function(){return f.l().substr(0,3)},<br />
j: function(){return jsdate.getDate()},<br />
l: function(){return txt_weekdays[f.w()]},<br />
N: function(){return f.w() + 1},<br />
S: function(){return txt_ordin[f.j()] ? txt_ordin[f.j()] : 'th'},<br />
w: function(){return jsdate.getDay()},<br />
z: function(){return (jsdate - new Date(jsdate.getFullYear() + "/1/1")) / 864e5 >> 0},<br />
<br />
// Week<br />
W: function(){<br />
var a = f.z(), b = 364 + f.L() - a;<br />
var nd2, nd = (new Date(jsdate.getFullYear() + "/1/1").getDay() || 7) - 1;<br />
if(b <= 2 && ((jsdate.getDay() || 7) - 1) <= 2 - b){<br />
return 1;<br />
} else{<br />
if(a <= 2 && nd >= 4 && a >= (6 - nd)){<br />
nd2 = new Date(jsdate.getFullYear() - 1 + "/12/31");<br />
return date("W", Math.round(nd2.getTime()/1000));<br />
} else{<br />
return (1 + (nd <= 3 ? ((a + nd) / 7) : (a - (7 - nd)) / 7) >> 0);<br />
}<br />
}<br />
},<br />
<br />
// Month<br />
F: function(){return txt_months[f.n()]},<br />
m: function(){return pad(f.n(), 2)},<br />
M: function(){return f.F().substr(0,3)},<br />
n: function(){return jsdate.getMonth() + 1},<br />
t: function(){<br />
var n;<br />
if( (n = jsdate.getMonth() + 1) == 2 ){<br />
return 28 + f.L();<br />
} else{<br />
if( n & 1 && n < 8 || !(n & 1) && n > 7 ){<br />
return 31;<br />
} else{<br />
return 30;<br />
}<br />
}<br />
},<br />
<br />
// Year<br />
L: function(){var y = f.Y();return (!(y & 3) && (y % 1e2 || !(y % 4e2))) ? 1 : 0},<br />
//o not supported yet<br />
Y: function(){return jsdate.getFullYear()},<br />
y: function(){return (jsdate.getFullYear() + "").slice(2)},<br />
<br />
// Time<br />
a: function(){return jsdate.getHours() > 11 ? "pm" : "am"},<br />
A: function(){return f.a().toUpperCase()},<br />
B: function(){<br />
// peter paul koch:<br />
var off = (jsdate.getTimezoneOffset() + 60)*60;<br />
var theSeconds = (jsdate.getHours() * 3600) + (jsdate.getMinutes() * 60) + jsdate.getSeconds() + off;<br />
var beat = Math.floor(theSeconds/86.4);<br />
if (beat > 1000) beat -= 1000;<br />
if (beat < 0) beat += 1000;<br />
if ((String(beat)).length == 1) beat = "00"+beat;<br />
if ((String(beat)).length == 2) beat = "0"+beat;<br />
return beat;<br />
},<br />
g: function(){return jsdate.getHours() % 12 || 12},<br />
G: function(){return jsdate.getHours()},<br />
h: function(){return pad(f.g(), 2)},<br />
H: function(){return pad(jsdate.getHours(), 2)},<br />
i: function(){return pad(jsdate.getMinutes(), 2)},<br />
s: function(){return pad(jsdate.getSeconds(), 2)},<br />
//u not supported yet<br />
<br />
// Timezone<br />
//e not supported yet<br />
//I not supported yet<br />
O: function(){<br />
var t = pad(Math.abs(jsdate.getTimezoneOffset()/60*100), 4);<br />
if (jsdate.getTimezoneOffset() > 0) t = "-" + t; else t = "+" + t;<br />
return t;<br />
},<br />
P: function(){var O = f.O();return (O.substr(0, 3) + ":" + O.substr(3, 2))},<br />
//T not supported yet<br />
//Z not supported yet<br />
<br />
// Full Date/Time<br />
c: function(){return f.Y() + "-" + f.m() + "-" + f.d() + "T" + f.h() + ":" + f.i() + ":" + f.s() + f.P()},<br />
//r not supported yet<br />
U: function(){return Math.round(jsdate.getTime()/1000)}<br />
};<br />
<br />
return format.replace(/[\\]?([a-zA-Z])/g, function(t, s){<br />
if( t!=s ){<br />
// escaped<br />
ret = s;<br />
} else if( f[s] ){<br />
// a date function exists<br />
ret = f[s]();<br />
} else{<br />
// nothing special<br />
ret = s;<br />
}<br />
return ret;<br />
});<br />
}<br />
<br />
<br />
<br />
function IsPinYer(yer){ //判断润平年 返回真2月29天<br />
return(0==yer%4 && (yer%100!=0 || yer%100==0));<br />
}<br />
</script><br>
AD:真正免费,域名+虚机+企业邮箱=0元

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

《Go語言程式設計實例:Web開發中的程式碼範例》隨著網路的快速發展,Web開發已成為各行業中不可或缺的一部分。作為一門功能強大且效能優越的程式語言,Go語言在Web開發中越來越受到開發者們的青睞。本文將透過具體的程式碼範例,介紹如何利用Go語言進行Web開發,讓讀者更能理解並運用Go語言來建立自己的Web應用。 1.簡單的HTTP伺服器首先,讓我們從一個

了解Python程式設計的入門程式碼範例Python是一種簡單易學,功能強大的程式語言。對於初學者來說,了解Python程式設計的入門級程式碼範例是非常重要的。本文將為您提供一些具體的程式碼範例,幫助您快速入門。列印HelloWorldprint("HelloWorld")這是Python中最簡單的程式碼範例。 print()函數用於將指定的內容輸出

PHP變數儲存程式運行期間的值,對於建立動態且互動的WEB應用程式至關重要。本文將深入探討php變量,並透過10個真實的範例展示它們的實際應用。 1.儲存使用者輸入$username=$_POST["username"];$passWord=$_POST["password"];此範例從表單提交中提取使用者名稱和密碼,並將其儲存在變數中以供進一步處理。 2.設定配置值$database_host="localhost";$database_username="username";$database_pa

Java冒泡排序最簡單的程式碼範例冒泡排序是一種常見的排序演算法,它的基本想法是透過相鄰元素的比較和交換來將待排序序列逐步調整為有序序列。以下是一個簡單的Java程式碼範例,示範如何實作冒泡排序:publicclassBubbleSort{publicstaticvoidbubbleSort(int[]arr){int

如何使用PHP編寫庫存管理系統中的庫存分倉管理功能碼庫存管理是許多企業中不可或缺的一部分。對於擁有多個倉庫的企業來說,庫存分倉管理功能尤其重要。透過合理管理和追蹤庫存,企業可以實現不同倉庫之間的庫存調撥,優化營運成本,改善協同效率。本文將介紹如何使用PHP編寫庫存分倉管理功能的程式碼,並為您提供相關的程式碼範例。一、建立資料庫在開始編寫庫存分倉管理功能的程式碼之

華為雲端邊緣運算對接指南:Java程式碼範例快速實現介面隨著物聯網技術的快速發展和邊緣運算的興起,越來越多的企業開始關注邊緣運算的應用。華為雲端提供了邊緣運算服務,為企業提供了高可靠的運算資源和便利的開發環境,使得邊緣運算應用更容易實現。本文將介紹如何透過Java程式碼快速實現華為雲端邊緣運算的介面。首先,我們需要準備好開發環境。確保你已經安裝了Java開發工具包(

標題:從入門到精通:Go語言中常用資料結構的程式碼實作資料結構在程式設計中起著至關重要的作用,它是程式設計的基礎。在Go語言中,有許多常用的資料結構,掌握這些資料結構的實作方式對於成為優秀的程式設計師至關重要。本文將介紹Go語言中常用的資料結構,並給出對應的程式碼範例,幫助讀者從入門到精通這些資料結構。 1.數組(Array)數組是一種基本的資料結構,是一組相同類型

Java選擇排序法程式碼編寫指南及範例選擇排序是一種簡單直觀的排序演算法,其想法是每次從未排序的元素中選擇最小(或最大)的元素進行交換,直到所有元素排序完成。本文將提供選擇排序的程式碼編寫指南,並附上具體的Java範例程式碼。演算法原理選擇排序的基本原理是將待排序數組分為已排序和未排序兩部分,每次從未排序部分選擇最小(或最大)的元素,將其放到已排序部分的末尾。重複上述
