当前位置:编程学习 > JS >>

javascript中日间日期的用法

var date = new Date();
date.getYear(); //获取当前年份(2位)
date.getFullYear(); //获取完整的年份(4位,1970-????)
date.getMonth(); //获取当前月份(0-11,0代表1月)
date.getDate(); //获取当前日(1-31)
date.getDay(); //获取当前星期X(0-6,0代表星期天)
date.getTime(); //获取当前时间(从1970.1.1开始的毫秒数)
date.getHours(); //获取当前小时数(0-23)
date.getMinutes(); //获取当前分钟数(0-59)
date.getSeconds(); //获取当前秒数(0-59)
date.getMilliseconds(); //获取当前毫秒数(0-999)
date.toLocaleDateString(); //获取当前日期
var time=date.toLocaleTimeString(); //获取当前时间
date.toLocaleString( ); //获取日期与时间

 

<script language="网页特效" type="text/javascript">
       function ShowTime() {
           document.getElementById("time").innerHTML = new Date().toLocaleTimeString(); //获取当前系统时间
           setTimeout("ShowTime()", 1000);//设置定时刷新 一秒更新一次
       }
       function DateDemo() {
           var d, day = "";  //声明变量
           d = new Date(); //创建Date对象www.zhutiai.com
           var week = new Array("星期日", "星期一", "星期二", "星期三", "星期四", "星期五", "星期六");
           day += d.getFullYear() + "年";     //获取年份
           day += (d.getMonth() + 1) + "月"; //获取月份
           day += d.getDate() + "日";        //获取日
           day += week[d.getDay()];
           document.getElementById("time").title = day;
       }
       ShowTime(); DateDemo();
   </script>

<span id="time"></span>

 

相关函数

function getMainHead() {

            $("LabelWelcome").innerHTML = GetWelcomeByTime() + "        今天是:" + GetSimpleDate() + "  " + GetWeekDay() + "     " + GetCnDate() + SolarTerm(new Date());

        }

function GetWelcomeByTime() {

    var now = new Date();

    var hour = now.getHours();

    var hello = "";

 

    if (hour < 4) {

        hello = "夜深了";

    }

    else if (hour < 7) {

        hello = "早安";

    }

    else if (hour < 9) {

        hello = "早上好";

    }

    else if (hour < 12) {

        hello = "上午好";

    }

    else if (hour < 14) {

        hello = "中午好";

    }

    else if (hour < 17) {

        hello = "下午好";

    }

    else if (hour < 19) {

        hello = "您好";

    }

    else if (hour < 22) {

        hello = "晚上好";

    }

    else {

        hello = "夜深了";

    }

 

    return hello;

}

function GetSimpleDate() {

    var today = new Date();

    var date = (today.getYear() < 100 ? today.getYear() + 1900 : today.getYear()) + "年" + (today.getMonth() + 1) + "月" + today.getDate() + "日";

    return date;

}

function GetWeekDay() {

    var today = new Date();

    var weeks = new Array("星期日", "星期一", "星期二", "星期三", "星期四", "星期五", "星期六");

    return weeks[today.getDay()];

}

//获取农历日期

function GetCnDate() {

    var today = new Date();

    return CnDateofDateStr(today);

}

function CnDateofDateStr(DateGL) {

    if (CnMonthofDate(DateGL) == "零月") return " 请调整您的计算机日期!";

    else return "农历:" + CnYearofDate(DateGL) + " " + CnMonthofDate(DateGL) + CnDayofDate(DateGL);

}

function SolarTerm(DateGL) {

    var SolarTermStr = new Array(

        "小寒", "大寒", "立春", "雨水", "惊蛰", "春分",

        "清明", "谷雨", "立夏", "小满", "芒种", "夏至",

        "小暑", "大暑", "立秋", "处暑", "白露", "秋分",

        "寒露", "霜降", "立冬", "小雪", "大雪", "冬至");

    var DifferenceInMonth = new Array(

        1272060, 1275495, 1281180, 1289445, 1299225, 1310355,

        1321560, 1333035, 1342770, 1350855, 1356420, 1359045,

        1358580, 1355055, 1348695, 1340040, 1329630, 1318455,

        1306935, 1297380, 1286865, 1277730, 1274550, 1271556);

    var DifferenceInYear = 31556926;

    var BeginTime = new Date(1901 / 1 / 1);

    BeginTime.setTime(947120460000);

    for (; DateGL.getYear() < BeginTime.getYear(); ) {

        BeginTime.setTime(BeginTime.getTime() - DifferenceInYear * 1000);

    }

    for (; DateGL.getYear() > BeginTime.getYear(); ) {

        BeginTime.setTime(BeginTime.getTime() + DifferenceInYear * 1000);

    }

    for (var M = 0; DateGL.getMonth() > BeginTime.getMonth(); M++) {

        BeginTime.setTime(BeginTime.getTime() + DifferenceInMonth[M] * 1000);

    }

    if (DateGL.getDate() > BeginTime.getDate()) {

        BeginTime.setTime(BeginTime.getTime() + DifferenceInMonth[M] * 1000);

        M++;

    }

    if (DateGL.getDate() > BeginTime.getDate()) {

        BeginTime.setTime(BeginTime.getTime() + DifferenceInMonth[M] * 1000);

        M == 23 ? M = 0 : M++;

    }

    var JQ;

    if (DateGL.getDate() == BeginTime.getDate()) {

        JQ = "  今天是<font color='#FF9999'><b>" + SolarTermStr[M] + "</b></font>";

    }

    else {

        JQ = " "

    }

    return JQ;

}

Javascript无刷新获取当前时间 在项目中需要无刷新更新时间,并且TooTip中显示年月日星期,网上搜集了很多方法,总结一下,以备下次之需。

view sourceprint?<script language="javascript" type="text/javascript"> 

       function ShowTime() { 

           document.getElementById("time").innerHTML = new Date().toLocaleTimeString(); //获取当前系统时间 

           setTimeout("ShowTime()", 1000);//设置定时刷新 一秒更新一次 

       } 

       function DateDemo() { 

           var d, day = "";  //声明变量 

           d = new Date(); //创建Date对象 

           var week = new Array("星期日", "星期一", "星期二", "星期三", "星期四", "星期五", "星期六"); 

           day += d.getFullYear() + "年";     //获取年份 

           day += (d.getMonth() + 1) + "月"; //获取月份 

           day += d.getDate() + "日";        //获取日 

           day += week[d.getDay()]; 

           document.getElementById("time").title = day; 

       } 

       ShowTime(); DateDemo(); 

   </script> 

 

<span id="time"></span>
view sourceprint?这里在<span>中显示当前时间,鼠标移上,显示当前年月日星期。类似Windows系统下面的时间。

JS 取得当前时间日期: 我们也可以自己组合显示格式

view sourceprint?var date = new Date(); 

date.getYear(); //获取当前年份(2位) 

date.getFullYear(); //获取完整的年份(4位,1970-????) 

date.getMonth(); //获取当前月份(0-11,0代表1月) 

date.getDate(); //获取当前日(1-31) 

date.getDay(); //获取当前星期X(0-6,0代表星期天) 

date.getTime(); //获取当前时间(从1970.1.1开始的毫秒数) 

date.getHours(); //获取当前小时数(0-23) 

date.getMinutes(); //获取当前分钟数(0-59) 

date.getSeconds(); //获取当前秒数(0-59) 

date.getMilliseconds(); //获取当前毫秒数(0-999) 

date.toLocaleDateString(); //获取当前日期 

var time=date.toLocaleTimeString(); //获取当前时间 

date.toLocaleString( ); //获取日期与时间

 

Date.prototype.format = function(format)
{
var o = {
"M+" : this.getMonth()+1, //month
"d+" : this.getDate(), //day
"h+" : this.getHours(), //hour
"m+" : this.getMinutes(), //minute
"s+" : this.getSeconds(), //second
"q+" : Math.floor((this.getMonth()+3)/3), //quarter
"S" : this.getMilliseconds() //millisecond
}
if(/(y+)/.test(format)) format=format.replace(RegExp.$1,
(this.getFullYear()+"").substr(4 - RegExp.$1.length));
for(var k in o)if(new RegExp("("+ k +")").test(format))
format = format.replace(RegExp.$1,
RegExp.$1.length==1 ? o[k] :
("00"+ o[k]).substr((""+ o[k]).length));
return format;
}

 

以上代码必须先声明,然后在使用。使用方法:
var d = new Date().format('yyyy-MM-dd');

 

另一种方法:
在Javascript之中,日期对象是Date,那么如何将一个日期对象按照定制的格式进行输出呢?
  可以现告诉你,Date对象有有四个内置方法,用于输出为字符串格式,分别为:
  1)toGMTString,将一个日期按照GMT格式显示
  2)toLocaleString,将一个日期按照本地操作系统格式显示
  3)toLocaleDateString,按照本地格式显示一个日期对象的日期部分
  4)toLocaleTimeString,按照本地格式显示一个日期对象的时间部分
  尽管Javascript的Date对象中内置提供了这些输出为字符串的方法,但是这些字符串不是我们来控制格式的,因此如果我们需要我们自己定制的特殊格式,那么又该怎么办呢?
  不用着急,JsJava中提供了专用的类,专门对日期进行指定格式的字符串输出,你可以下载JsJava-2.0.zip,引入其中的src/jsjava/text/DateFormat.js,或者直接引入jslib/jsjava-2.0.js,样例代码如下: 
var df=new SimpleDateFormat();//jsJava1.0需要使用DateFormat对象,不要弄错就是了
df.applyPattern("yyyy-MM-dd HH:mm:ss");
var date=new Date(2007,3,30,10,59,51);
var str=df.format(date);
document.write(str);//显示结果为:2007-04-30 10:59:51
通过上面的例子你可以看出,你需要做的就是指定pattern,那么pattern中yyyy、MM等都表示什么意思呢?如果你学习过Java的日期格式化,那么你应该知道,那都是占位符,这些占位符都具有特殊的函数,例如y表示年,yyyy表示四个数字的年份,例如1982,下面列举一些pattern中支持的特殊字符及其含义(下面表格引自Java的官方文档,做了适当修改):
G Era designator [url=]Text[/url] AD
y Year [url=]Year[/url] 1996; 96
M Month in year [url=]Month[/url] July; Jul; 07
w Week in year [url=]Number[/url] 27
W Week in month [url=]Number[/url] 2
D Day in year [url=]Number[/url] 189
d Day in month [url=]Number[/url] 10
F Day of week in month [url=]Number[/url] 2
E Day in week [url=]Text[/url] Tuesday; Tue
a Am/pm marker [url=]Text[/url] PM
H Hour in day (0-23) [url=]Number[/url] 0
k Hour in day (1-24) [url=]Number[/url] 24
K Hour in am/pm (0-11) [url=]Number[/url] 0
h Hour in am/pm (1-12) [url=]Number[/url] 12
m Minute in hour [url=]Number[/url] 30
s Second in minute [url=]Number[/url] 55
S Millisecond [url=]Number[/url] 978
补充:网页制作,js教程
CopyRight © 2022 站长资源库 编程知识问答 zzzyk.com All Rights Reserved
部分文章来自网络,