dateObj = new Date(dateVal)
dateObj必选项。要赋值为 Date 对象的变量名。dateVal必选项。如果是数字值,dateVal 表示指定日期与 1970 年 1 月 1 日午夜间全球标准时间 的毫秒数。如果是字符串,则 dateVal 按照 parse 方法中的规则进行解析。dateVal 参数也可以是从某些 ActiveX(R) 对象返回的 VT_DATE 值。
------------------------------------------------------
你输入的是准确的毫秒数?
dateObj必选项。要赋值为 Date 对象的变量名。dateVal必选项。如果是数字值,dateVal 表示指定日期与 1970 年 1 月 1 日午夜间全球标准时间 的毫秒数。如果是字符串,则 dateVal 按照 parse 方法中的规则进行解析。dateVal 参数也可以是从某些 ActiveX(R) 对象返回的 VT_DATE 值。
------------------------------------------------------
你输入的是准确的毫秒数?
解决方案 »
- JS实现浏览器F11全屏
- jQuery autocomplete 问题 在线急求大牛!!!
- javascript可以让asp的dropdownlist的项隐藏吗?enabled和visible好像都不管用
- 为什么火狐浏览器无法显示图片??
- 如何防止被别人的网站框架自己?
- javascript如何读写一个文本文件(不需要服务器解析)
- input下拉提示,不知道能不能用
- 请教非ie浏览器下 移动 层(div)的代码?
- js与vbs间的数据传递问题,请问大家了,谢谢大家的帮助啊
- 分享:JavaScript实现在线编辑表格
- 如何用js控制链接的target属性?
- 怎么在添加表格行的时候,某列是个按钮,用innerHTML老出问题
不过用这个之前要先调用是不是符合日期格式的函数
然后检验不通过清空数据。按你的思路改了下。
还有个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>
<!--
/*用相对不规则的字符串来创建日期对象,不规则的含义为:顺序包含年月日三个数值串,有间隔*/
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>
hbhbhbhbhb1021(天外水火(我要多努力)),
我后来想想可能那种办法也不行,
因为日期格式验证是在提交后验证的,
所以在onchange调用函数比较大小前,无法确定两个文本框的格式正确,
请帮我想想有没有其他好办法没有,好吗,
如果实在不行,可能我只能在SERVLET中用JAVA代码验证了,这是我最不想用的办法,
因为重用性很差,kangqin(小康) ( )
没有精确到毫秒,就是象2005-5-5这样的zhaoxiaoyang(梅雪香@深圳)
很谢谢你的留言,不过我对JS脚本不是很懂,
所以,看不懂你的函数,不好意思,
在提交表单的时候检查时间是不是输入和大小关系。
如果条件允许,最好在后台程序也验证下,防止别人发请求乱搞。
写了个例子
<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>