dateObj = new Date(dateVal)
dateObj必选项。要赋值为 Date 对象的变量名。dateVal必选项。如果是数字值,dateVal 表示指定日期与 1970 年 1 月 1 日午夜间全球标准时间 的毫秒数。如果是字符串,则 dateVal 按照 parse 方法中的规则进行解析。dateVal 参数也可以是从某些 ActiveX(R) 对象返回的 VT_DATE 值。
------------------------------------------------------
你输入的是准确的毫秒数?

解决方案 »

  1.   

    晕,我试了下第一个不填也没报错。
    不过用这个之前要先调用是不是符合日期格式的函数
    然后检验不通过清空数据。按你的思路改了下。
    还有个BUG就是怕用户不向t2输入,就调不到这个函数,所以还是觉得在表单提交的时候检查表单这两个选项是不是空,然后判断大小。在这里的onchange只调用检查日期格式是不是正确的函数,不正确清空,不能设焦点,因为两个输入框可能有死循环情况。
    <script type="text/javascript">
    function xlh(){
    var t2=document.getElementById("t2");
    var d1 = new Date(document.getElementById("t1").value.replace(/-/g,"/"));
    var d2 = new Date(t2.value.replace(/-/g,"/"));
    var flag = (d1<d2) ? true : false;
    if(!flag)
    {
         alert("错误");
         t2.value='';
         t2.focus();
    }
    }
    </script>
      

  2.   

    <script language="JavaScript">
    <!--
    /*用相对不规则的字符串来创建日期对象,不规则的含义为:顺序包含年月日三个数值串,有间隔*/
    String.prototype.parseDate = function(){
    var regThree = /^\D*(\d{2,4})\D+(\d{1,2})\D+(\d{1,2})\D*$/;
    var regSix = /^\D*(\d{2,4})\D+(\d{1,2})\D+(\d{1,2})\D+(\d{1,2})\D+(\d{1,2})\D+(\d{1,2})\D*$/;
    //var str = "";
    var date = null;
    if(regThree.test(this))
    date = new Date(this.replace(/\s/g,"").replace(regThree,"$1/$2/$3"));
    else if(regSix.test(this)){
    str = this.match(regSix);
    date = new Date(str[1],str[2]-1,str[3],str[4],str[5],str[6]);
    }else return new Date();
    return date;
    }/*
     * 功能:根据输入表达式返回日期字符串
     * 参数:dateFmt:字符串,由以下结构组成    
     *      yy:长写年,YY:短写年mm:数字月,MM:英文月,dd:日,hh:时,
     *      mi:分,ss秒,ms:毫秒,we:汉字星期,WE:英文星期.
     *      isFmtWithZero : 是否用0进行格式化,true or false
    */
    Date.prototype.parseString = function(dateFmt,isFmtWithZero){
    dateFmt = (dateFmt == null?"yy-mm-dd" : dateFmt);
    isFmtWithZero = (isFmtWithZero == null?true : isFmtWithZero);
    if(typeof(dateFmt) != "string" )
    throw (new Error(-1, 'parseString()方法需要字符串类型参数!'));
    var weekArr=[["星期日","星期一","星期二","星期三","星期四","星期五","星期六"],
      ["SUN","MON","TUR","WED","THU","FRI","SAT"]];
    var monthArr=["JAN","FEB","MAR","APR","MAY","JUN","JUL","AUG","SEP","OCT","NOV","DEC"];
    var str=dateFmt;
    var o = {
    "yy" : this.getFullYear(),
    "YY" : this.getYear(),
    "mm" : this.getMonth()+1,
    "MM" : monthArr[this.getMonth()],
    "dd" : this.getDate(),
    "hh" : this.getHours(),
    "mi" : this.getMinutes(),
    "ss" : this.getSeconds(),
    "we" : weekArr[0][this.getDay()],
    "WE" : weekArr[1][this.getDay()]
    }
    for(var i in o){
    str = str.replace(new RegExp(i,"g"),o[i].toString().fmtWithZero(isFmtWithZero));
    }
    str = str.replace(/ms/g,this.getMilliseconds().toString().fmtWithZeroD(isFmtWithZero));
    return str;
    }
    /*将一位数字格式化成两位,如: 9 to 09*/
    String.prototype.fmtWithZero = function(isFmtWithZero){
    return (isFmtWithZero && /^\d$/.test(this))?"0"+this:this;
    }
    String.prototype.fmtWithZeroD = function(isFmtWithZero){
    return (isFmtWithZero && /^\d{2}$/.test(this))?"00"+this:((isFmtWithZero && /^\d$/.test(this))?"0"+this:this);
    }/* 功能 : 返回与某日期相距N天(N个24小时)的日期
     * 参数 : num number类型 可以为正负整数或者浮点数,默认为1;
     *        type 0(秒) or 1(天),默认为天
     * 返回 : 新的PowerDate类型
     */
    Date.prototype.dateAfter=function(num,type){
    num = (num == null?1:num);
    if(typeof(num)!="number") throw new Error(-1,"dateAfterDays(num,type)的num参数为数值类型.");
    type = (type==null?1:type);
    var arr = [1000,86400000];
    return new Date(this.valueOf() + num*arr[type]);
    }//判断是否是闰年,返回true 或者 false
    Date.prototype.isLeapYear = function (){
    var year = this.getFullYear();
    return (0==year%4 && ((year % 100 != 0)||(year % 400 == 0)));
    }//返回该月天数
    Date.prototype.getDaysOfMonth = function (){
    return (new Date(this.getFullYear(),this.getMonth()+1,0)).getDate();
    }//日期比较函数,参数date:为Date类型,如this日期晚于参数:1,相等:0 早于: -1
    Date.prototype.dateCompare = function(date){
    if(typeof(date) != "object" || !(/Date/.test(date.constructor)))
     throw new Error(-1,"dateCompare(date)的date参数为Date类型.");
    var d = this.getTime() - date.getTime();
    return d>0?1:(d==0?0:-1);
    }/*功能:返回两日期之差
     *参数:pd   PowerDate对象
     *    type: 返回类别标识.yy:年,mm:月,ww:周,dd:日,hh:小时,mi:分,ss:秒,ms:毫秒
     *    intOrFloat :返回整型还是浮点型值 0:整型,不等于0:浮点型
     *    output : 输出提示,如:时间差为#周!
     */
    Date.prototype.calDateDistance = function (date,type,intOrFloat,output){
    if(typeof(date) != "object" || !(/Date/.test(date.constructor)))
     throw new Error(-1,"calDateDistance(date,type,intOrFloat)的date参数为Date类型.");
    type = (type==null?'dd':type);
    if(!((new RegExp(type+",","g")).test("yy,mm,ww,dd,hh,mi,ss,ms,")))
     throw new Error(-1,"calDateDistance(pd,type,intOrFloat,output)的type参数为非法.");
    var iof = (intOrFloat==null?0:intOrFloat);
    var num=0;
    var o = {
    "ww" : 7*86400000,
    "dd" : 86400000,
    "hh" : 3600000,
    "mi" : 60000,
    "ss" : 1000,
    "ms" : 1
    }
    switch(type){
    case "yy": num = this.getFullYear() - date.getFullYear(); break;
    case "mm": num = (this.getFullYear() - date.getFullYear())*12+this.getMonth()-date.getMonth(); break;
    default: 
    var sub = this.valueOf() - date.valueOf();
    if (o[type])
    num = (sub/o[type]).fmtRtnVal(iof);
    break;
    }
    return (output ? output.replace(/#/g," "+num+" ") : num);
    }
    //返回整数或者两位小数的浮点数
    Number.prototype.fmtRtnVal = function (intOrFloat){
    return (intOrFloat == 0 ? Math.floor(this) : parseInt(this*100)/100);
    }
    //根据当前日期所在年和周数返回周日的日期
    Date.prototype.RtnByWeekNum = function (weekNum){
    if(typeof(weekNum) != "number")
    throw new Error(-1,"RtnByWeekNum(weekNum)的参数是数字类型.");
    var date = new Date(this.getFullYear(),0,1);
    var week = date.getDay();
    week = (week==0?7:week);
    return date.dateAfter(weekNum*7-week,1);
    }
    //根据日期返回该日期所在年的周数
    Date.prototype.getWeekNum = function (){
    var dat = new Date(this.getFullYear(),0,1);
    var week = dat.getDay();
    week = (week==0?7:week);
    var days = this.calDateDistance(dat,"dd")+1;
    return ((days + 6 - this.getDay() - 7 + week)/7);
    }//-->
    </script><script language="JavaScript">
    <!--
    var date1 = "2005-11-1";
    var date3 = "2006-1-10 11 11 11".parseDate();
    var date2 = "2005-12-30".parseDate();
    //alert(date3);
    alert(date3.calDateDistance(date2,null,null,"时间差为#天!"));//-->
    </script>
      

  3.   

    谢谢各位的答复,
    hbhbhbhbhb1021(天外水火(我要多努力)),
    我后来想想可能那种办法也不行,
    因为日期格式验证是在提交后验证的,
    所以在onchange调用函数比较大小前,无法确定两个文本框的格式正确,
    请帮我想想有没有其他好办法没有,好吗,
    如果实在不行,可能我只能在SERVLET中用JAVA代码验证了,这是我最不想用的办法,
    因为重用性很差,kangqin(小康) ( ) 
    没有精确到毫秒,就是象2005-5-5这样的zhaoxiaoyang(梅雪香@深圳) 
    很谢谢你的留言,不过我对JS脚本不是很懂,
    所以,看不懂你的函数,不好意思,
      

  4.   

    先在输入后马上检查时间的正确性
    在提交表单的时候检查时间是不是输入和大小关系。
    如果条件允许,最好在后台程序也验证下,防止别人发请求乱搞。
    写了个例子
    <script language=javascript>
    function checkform()
    {
    var strDate1=document.getElementById("date1").value;
    var strDate2=document.getElementById("date2").value;
    if(strDate1=="")
    {
    alert("日期1没填");
    }
    if(strDate2=="")
    {
    alert("日期2没填");
    }
    var DateArray1=strDate1.split("-");
    var dateElement1=new Date(DateArray1[0],parseInt(DateArray1[1])-1,DateArray1[2]);
    var DateArray2=strDate2.split("-");
    var dateElement2=new Date(DateArray2[0],parseInt(DateArray2[1])-1,DateArray2[2]);
    if(dateElement1<=dateElement2)
    {
    form1.submit();
    }
    else
    {
    alert("日期1必须小于日期2")
    }
    }
    function checkDate(obj)//判断日期格式是不是符合
    {
    var strDate=obj.value;
    re=/\d{4}\-\d{2}-\d{2}/g
    if(re.test(strDate))//判断日期格式符合YYYY-MM-DD标准
    {
    var DateArray=strDate.split("-");
    var dateElement=new Date(DateArray[0],parseInt(DateArray[1])-1,DateArray[2]);
    if(!((dateElement.getFullYear()==parseInt(DateArray[0]))&&((dateElement.getMonth()+1)==parseInt(DateArray[1]))&&(dateElement.getDate()==parseInt(DateArray[2]))))//判断日期逻辑
    {
    alert("不符合时间逻辑")
    obj.value='';
    }
    }
    else
    {
    alert("格式输入错误")
    obj.value='';
    }
    }
    </script>
    <form name=form1 method=post action="http://www.csdn.net">
    <input name=date1 onblur=checkDate(this)><!-- 格式必须为yyyy-mm-dd格式 -->
    <input name=date2 onblur=checkDate(this)>
    <input name=button1 type=button value="提交" onclick=checkform()>
    </form>