前言 本篇的介紹涵蓋以下部分:
1. 時間標准指的是什麼?UCT和GMT 的概念、關聯和區別?
2. 時間表示標准有哪些?
3. JS 中時間的處理
日期時間標准
日期的標准就不多說了 -- 公元紀年
是為紀念猶太人耶稣(基督)的誕生。他誕生的那一年為公元1年,誕生之前的年份稱為“公元前n年”
簡單來說,時間的標准就是以什麼時間為起點開始計時。對於年份來說,舉例來說,如果不使用公元紀年法,估計全世界交流起來就困難重重了(新中國54年,估計很把很多老外整暈)
時間標准其實挺多的。
原子時 · 協調世界時(UTC) · 格林尼治平時(GMT) · 地球時(TT) · 力學時(DT)
在程序開發中甚至日常生活中,比較常見的就是UTC和GMT了。
UTC是協調世界時(Universal Time Coordinated)英文縮寫,是由國際無線電咨詢委員會規定和推薦,並由國際時間局(BIH)負責保持的以秒為基礎的時間標度。UTC相當於本初子午線(即經度0度)上的平均太陽時,過去曾用格林威治平均時(GMT)來表示.北京時間比UTC時間早8小時,以1999年1月1日0000UTC為例,UTC時間是零點,北京時間為1999年1月1日早上8點整。
GMT(Greenwich Mean Time)是格林尼治平時:
由於地球軌道並非圓形,其運行速度又隨著地球與太陽的距離改變而出現變化,因此視太陽時欠缺均勻性。視太陽日的長度同時亦受到地球自轉軸相對軌道面的傾斜度所影響。為著要糾正上述的不均勻性,天文學家計算地球非圓形軌跡與極軸傾斜對視太陽時的效應。平太陽時就是指經修訂後的視太陽時。在格林尼治子午線上的平太陽時稱為世界時(UT0),又叫格林尼治平時(GMT)。
為了確保協調世界時與世界時(UT1)相差不會超過0.9秒,有需要時便會在協調世界時內加上正或負閏秒。因此協調世界時與國際原子時(TAI)之間會出現若干整數秒的差別。位於巴黎的國際地球自轉事務中央局(IERS)負責決定何時加入閏秒。
兩者的關系:
UTC = GMT +/- 0.9 s
因此 UTC 間中需要進行 "閏秒" 以控制兩者相差。
以上介紹可以統統不看, 一言之,UTC和 GMT就是世界標准時間, 兩者的差距很小。
日期時間表示標准 日期和時間的計算標准有了。但是表示上卻也可以千差萬異。
2013/08/16
08/16/2013
13/08/16
.。。。。。
於是,國際標准化組織ISO 出來了,制定了一個8601系列 《數據存儲和交換形式·信息交換·日期和時間的表示方法》。
目前是第三版ISO8601:2004以替代第一版ISO8601:1988與第二版ISO8601:2000。
主要的部分列一下:
1. 日期表示法
年為4位數,月為2位數,月中的日為2位數,例如,日期(2013年8月16日)可表示為2013-08-16,或20130816。
2. 日歷星期和日表示法
可以用2位數表示本年內第幾個日歷星期;
每個日歷星期從星期一開始,星期日為第7天
3. 時間表示方法
小時、分和秒都用2位數表示,對UTC時間最後加一個大寫字母Z,其他時區用實際時間加時差表示。如UTC時間下午2點30分5秒表示為14:30:05Z或143005Z,當時的北京時間表示為22:30:05+08:00或223005+0800,也可以簡化成223005+08。
4. 日期和時間組合表示法
合並表示時,要在時間前面加一大寫字母T,如要表示北京時間2004年5月3日下午5點30分8秒,可以寫成2004-05-03T17:30:08+08:00或20040503T173008+08。
需要特別提出來說的是:
星期天在西方是作為一個星期的第一天
在中國則是最後一天。
也就是所ISO標准和中國的習慣是一致的。但是目前許多軟件、語言什麼的都是國外開發的,時間上還是延續了他們自己的習慣。
Javascript 中的日期時間
方法 |
描述 |
FF |
IE |
Date()
返回當日的日期和時間。
1
3
getDate()
從 Date 對象返回一個月中的某一天 (1 ~ 31)。
1
3
getDay()
從 Date 對象返回一周中的某一天 (0 ~ 6)。
1
3
getMonth()
從 Date 對象返回月份 (0 ~ 11)。
1
3
getFullYear()
從 Date 對象以四位數字返回年份。
1
4
getYear()
請使用 getFullYear() 方法代替。
1
3
getHours()
返回 Date 對象的小時 (0 ~ 23)。
1
3
getMinutes()
返回 Date 對象的分鐘 (0 ~ 59)。
1
3
getSeconds()
返回 Date 對象的秒數 (0 ~ 59)。
1
3
getMilliseconds()
返回 Date 對象的毫秒(0 ~ 999)。
1
4
getTime()
返回 1970 年 1 月 1 日至今的毫秒數。
1
3
getTimezoneOffset()
返回本地時間與格林威治標准時間 (GMT) 的分鐘差。
1
3
getUTCDate()
根據世界時從 Date 對象返回月中的一天 (1 ~ 31)。
1
4
getUTCDay()
根據世界時從 Date 對象返回周中的一天 (0 ~ 6)。
1
4
getUTCMonth()
根據世界時從 Date 對象返回月份 (0 ~ 11)。
1
4
getUTCFullYear()
根據世界時從 Date 對象返回四位數的年份。
1
4
getUTCHours()
根據世界時返回 Date 對象的小時 (0 ~ 23)。
1
4
getUTCMinutes()
根據世界時返回 Date 對象的分鐘 (0 ~ 59)。
1
4
getUTCSeconds()
根據世界時返回 Date 對象的秒鐘 (0 ~ 59)。
1
4
getUTCMilliseconds()
根據世界時返回 Date 對象的毫秒(0 ~ 999)。
1
4
parse()
返回1970年1月1日午夜到指定日期(字符串)的毫秒數。
1
3
setDate()
設置 Date 對象中月的某一天 (1 ~ 31)。
1
3
setMonth()
設置 Date 對象中月份 (0 ~ 11)。
1
3
setFullYear()
設置 Date 對象中的年份(四位數字)。
1
4
setYear()
請使用 setFullYear() 方法代替。
1
3
setHours()
設置 Date 對象中的小時 (0 ~ 23)。
1
3
setMinutes()
設置 Date 對象中的分鐘 (0 ~ 59)。
1
3
setSeconds()
設置 Date 對象中的秒鐘 (0 ~ 59)。
1
3
setMilliseconds()
設置 Date 對象中的毫秒 (0 ~ 999)。
1
4
setTime()
以毫秒設置 Date 對象。
1
3
setUTCDate()
根據世界時設置 Date 對象中月份的一天 (1 ~ 31)。
1
4
setUTCMonth()
根據世界時設置 Date 對象中的月份 (0 ~ 11)。
1
4
setUTCFullYear()
根據世界時設置 Date 對象中的年份(四位數字)。
1
4
setUTCHours()
根據世界時設置 Date 對象中的小時 (0 ~ 23)。
1
4
setUTCMinutes()
根據世界時設置 Date 對象中的分鐘 (0 ~ 59)。
1
4
setUTCSeconds()
根據世界時設置 Date 對象中的秒鐘 (0 ~ 59)。
1
4
setUTCMilliseconds()
根據世界時設置 Date 對象中的毫秒 (0 ~ 999)。
1
4
toSource()
返回該對象的源代碼。
1
-
toString()
把 Date 對象轉換為字符串。
1
4
toTimeString()
把 Date 對象的時間部分轉換為字符串。
1
4
toDateString()
把 Date 對象的日期部分轉換為字符串。
1
4
toGMTString()
請使用 toUTCString() 方法代替。
1
3
toUTCString()
根據世界時,把 Date 對象轉換為字符串。
1
4
toLocaleString()
根據本地時間格式,把 Date 對象轉換為字符串。
1
3
toLocaleTimeString()
根據本地時間格式,把 Date 對象的時間部分轉換為字符串。
1
3
toLocaleDateString()
根據本地時間格式,把 Date 對象的日期部分轉換為字符串。
1
3
UTC()
根據世界時返回 1997 年 1 月 1 日 到指定日期的毫秒數。
1
3
valueOf()
返回 Date 對象的原始值。
以上也可以統統不看, 需要特別說的是:
Javascript 把 星期天 作為一周的開始。 使用getDay() 這個方法時就得小心了。
getDay() 返回 0-6 之間的數值, 2013/08/18 是星期天, 返回值是 0
復制代碼 代碼如下:
<!--Add by oscar999-->
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<HTML>
<HEAD>
<TITLE> New Document </TITLE>
<META NAME="Author" CONTENT="oscar999">
<script>
var date = new Date("2013/08/18");
alert(date.getDay());
</script>
</HEAD>
<BODY>
</BODY>
</HTML>