- 浏览: 459313 次
- 性别:
- 来自: 北京
-
文章分类
最新评论
-
yuan_bin1990:
您好,请问下demo如何运行啊,准备研究研究,但不知道入口啊。 ...
ssh2(struts2+spring2.5+hibernate3.3)自动生成代码程序 -
luyulong:
[b][/b][i][/i][ ...
jQuery进度条插件 jQuery progressBar -
txin0814:
mark..
读取文件目录 -
vurses:
[align=center][color=red][size= ...
include 与 jsp:include区别 -
Roshan2:
http://lijiejava.iteye.com/blog ...
Spring AOP 入门实例
Date.prototype.isLeapYear 判断闰年
Date.prototype.Format 日期格式化
Date.prototype.DateAdd 日期计算
Date.prototype.DateDiff 比较日期差
Date.prototype.toString 日期转字符串
Date.prototype.toArray 日期分割为数组
Date.prototype.DatePart 取日期的部分信息
Date.prototype.MaxDayOfDate 取日期所在月的最大天数
Date.prototype.WeekNumOfYear 判断日期所在年的第几周
StringToDate 字符串转日期型
IsValidDate 验证日期有效性
CheckDateTime 完整日期时间检查
daysBetween 日期天数差
js 代码
//--------------------------------------------------- // 判断闰年 //--------------------------------------------------- Date.prototype.isLeapYear = function() { return (0==this.getYear()%4&&((this.getYear()%100!=0)||(this.getYear()%400==0))); } //--------------------------------------------------- // 日期格式化 // 格式 YYYY/yyyy/YY/yy 表示年份 // MM/M 月份 // W/w 星期 // dd/DD/d/D 日期 // hh/HH/h/H 时间 // mm/m 分钟 // ss/SS/s/S 秒 //--------------------------------------------------- Date.prototype.Format = function(formatStr) { var str = formatStr; var Week = ['日','一','二','三','四','五','六']; str=str.replace(/yyyy|YYYY/,this.getFullYear()); str=str.replace(/yy|YY/,(this.getYear() % 100)>9?(this.getYear() % 100).toString():'0' + (this.getYear() % 100)); str=str.replace(/MM/,this.getMonth()>9?this.getMonth().toString():'0' + this.getMonth()); str=str.replace(/M/g,this.getMonth()); str=str.replace(/w|W/g,Week[this.getDay()]); str=str.replace(/dd|DD/,this.getDate()>9?this.getDate().toString():'0' + this.getDate()); str=str.replace(/d|D/g,this.getDate()); str=str.replace(/hh|HH/,this.getHours()>9?this.getHours().toString():'0' + this.getHours()); str=str.replace(/h|H/g,this.getHours()); str=str.replace(/mm/,this.getMinutes()>9?this.getMinutes().toString():'0' + this.getMinutes()); str=str.replace(/m/g,this.getMinutes()); str=str.replace(/ss|SS/,this.getSeconds()>9?this.getSeconds().toString():'0' + this.getSeconds()); str=str.replace(/s|S/g,this.getSeconds()); return str; } //+--------------------------------------------------- //| 求两个时间的天数差 日期格式为 YYYY-MM-dd //+--------------------------------------------------- function daysBetween(DateOne,DateTwo) { var OneMonth = DateOne.substring(5,DateOne.lastIndexOf ('-')); var OneDay = DateOne.substring(DateOne.length,DateOne.lastIndexOf ('-')+1); var OneYear = DateOne.substring(0,DateOne.indexOf ('-')); var TwoMonth = DateTwo.substring(5,DateTwo.lastIndexOf ('-')); var TwoDay = DateTwo.substring(DateTwo.length,DateTwo.lastIndexOf ('-')+1); var TwoYear = DateTwo.substring(0,DateTwo.indexOf ('-')); var cha=((Date.parse(OneMonth+'/'+OneDay+'/'+OneYear)- Date.parse(TwoMonth+'/'+TwoDay+'/'+TwoYear))/86400000); return Math.abs(cha); } //+--------------------------------------------------- //| 日期计算 //+--------------------------------------------------- Date.prototype.DateAdd = function(strInterval, Number) { var dtTmp = this; switch (strInterval) { case 's' :return new Date(Date.parse(dtTmp) + (1000 * Number)); case 'n' :return new Date(Date.parse(dtTmp) + (60000 * Number)); case 'h' :return new Date(Date.parse(dtTmp) + (3600000 * Number)); case 'd' :return new Date(Date.parse(dtTmp) + (86400000 * Number)); case 'w' :return new Date(Date.parse(dtTmp) + ((86400000 * 7) * Number)); case 'q' :return new Date(dtTmp.getFullYear(), (dtTmp.getMonth()) + Number*3, dtTmp.getDate(), dtTmp.getHours(), dtTmp.getMinutes(), dtTmp.getSeconds()); case 'm' :return new Date(dtTmp.getFullYear(), (dtTmp.getMonth()) + Number, dtTmp.getDate(), dtTmp.getHours(), dtTmp.getMinutes(), dtTmp.getSeconds()); case 'y' :return new Date((dtTmp.getFullYear() + Number), dtTmp.getMonth(), dtTmp.getDate(), dtTmp.getHours(), dtTmp.getMinutes(), dtTmp.getSeconds()); } } //+--------------------------------------------------- //| 比较日期差 dtEnd 格式为日期型或者 有效日期格式字符串 //+--------------------------------------------------- Date.prototype.DateDiff = function(strInterval, dtEnd) { var dtStart = this; if (typeof dtEnd == 'string' )//如果是字符串转换为日期型 { dtEnd = StringToDate(dtEnd); } switch (strInterval) { case 's' :return parseInt((dtEnd - dtStart) / 1000); case 'n' :return parseInt((dtEnd - dtStart) / 60000); case 'h' :return parseInt((dtEnd - dtStart) / 3600000); case 'd' :return parseInt((dtEnd - dtStart) / 86400000); case 'w' :return parseInt((dtEnd - dtStart) / (86400000 * 7)); case 'm' :return (dtEnd.getMonth()+1)+((dtEnd.getFullYear()-dtStart.getFullYear())*12) - (dtStart.getMonth()+1); case 'y' :return dtEnd.getFullYear() - dtStart.getFullYear(); } } //+--------------------------------------------------- //| 日期输出字符串,重载了系统的toString方法 //+--------------------------------------------------- Date.prototype.toString = function(showWeek) { var myDate= this; var str = myDate.toLocaleDateString(); if (showWeek) { var Week = ['日','一','二','三','四','五','六']; str += ' 星期' + Week[myDate.getDay()]; } return str; } //+--------------------------------------------------- //| 日期合法性验证 //| 格式为:YYYY-MM-DD或YYYY/MM/DD //+--------------------------------------------------- function IsValidDate(DateStr) { var sDate=DateStr.replace(/(^\s+|\s+$)/g,''); //去两边空格; if(sDate=='') return true; //如果格式满足YYYY-(/)MM-(/)DD或YYYY-(/)M-(/)DD或YYYY-(/)M-(/)D或YYYY-(/)MM-(/)D就替换为'' //数据库中,合法日期可以是:YYYY-MM/DD(2003-3/21),数据库会自动转换为YYYY-MM-DD格式 var s = sDate.replace(/[\d]{ 4,4 }[\-/]{ 1 }[\d]{ 1,2 }[\-/]{ 1 }[\d]{ 1,2 }/g,''); if (s=='') //说明格式满足YYYY-MM-DD或YYYY-M-DD或YYYY-M-D或YYYY-MM-D { var t=new Date(sDate.replace(/\-/g,'/')); var ar = sDate.split(/[-/:]/); if(ar[0] != t.getYear() || ar[1] != t.getMonth()+1 || ar[2] != t.getDate()) { //alert('错误的日期格式!格式为:YYYY-MM-DD或YYYY/MM/DD。注意闰年。'); return false; } } else { //alert('错误的日期格式!格式为:YYYY-MM-DD或YYYY/MM/DD。注意闰年。'); return false; } return true; } //+--------------------------------------------------- //| 日期时间检查 //| 格式为:YYYY-MM-DD HH:MM:SS //+--------------------------------------------------- function CheckDateTime(str) { var reg = /^(\d+)-(\d{ 1,2 })-(\d{ 1,2 }) (\d{ 1,2 }):(\d{ 1,2 }):(\d{ 1,2 })$/; var r = str.match(reg); if(r==null)return false; r[2]=r[2]-1; var d= new Date(r[1],r[2],r[3],r[4],r[5],r[6]); if(d.getFullYear()!=r[1])return false; if(d.getMonth()!=r[2])return false; if(d.getDate()!=r[3])return false; if(d.getHours()!=r[4])return false; if(d.getMinutes()!=r[5])return false; if(d.getSeconds()!=r[6])return false; return true; } //+--------------------------------------------------- //| 把日期分割成数组 //+--------------------------------------------------- Date.prototype.toArray = function() { var myDate = this; var myArray = Array(); myArray[0] = myDate.getFullYear(); myArray[1] = myDate.getMonth(); myArray[2] = myDate.getDate(); myArray[3] = myDate.getHours(); myArray[4] = myDate.getMinutes(); myArray[5] = myDate.getSeconds(); return myArray; } //+--------------------------------------------------- //| 取得日期数据信息 //| 参数 interval 表示数据类型 //| y 年 m月 d日 w星期 ww周 h时 n分 s秒 //+--------------------------------------------------- Date.prototype.DatePart = function(interval) { var myDate = this; var partStr=''; var Week = ['日','一','二','三','四','五','六']; switch (interval) { case 'y' :partStr = myDate.getFullYear();break; case 'm' :partStr = myDate.getMonth()+1;break; case 'd' :partStr = myDate.getDate();break; case 'w' :partStr = Week[myDate.getDay()];break; case 'ww' :partStr = myDate.WeekNumOfYear();break; case 'h' :partStr = myDate.getHours();break; case 'n' :partStr = myDate.getMinutes();break; case 's' :partStr = myDate.getSeconds();break; } return partStr; } //+--------------------------------------------------- //| 取得当前日期所在月的最大天数 //+--------------------------------------------------- Date.prototype.MaxDayOfDate = function() { var myDate = this; var ary = myDate.toArray(); var date1 = (new Date(ary[0],ary[1]+1,1)); var date2 = date1.dateAdd(1,'m',1); var result = dateDiff(date1.Format('yyyy-MM-dd'),date2.Format('yyyy-MM-dd')); return result; } //+--------------------------------------------------- //| 取得当前日期所在周是一年中的第几周 //+--------------------------------------------------- Date.prototype.WeekNumOfYear = function() { var myDate = this; var ary = myDate.toArray(); var year = ary[0]; var month = ary[1]+1; var day = ary[2]; document.write('< script language=VBScript\> \n'); document.write('myDate = DateValue(''+month+'-'+day+'-'+year+'') \n'); document.write('result = DatePart('ww', myDate) \n'); document.write(' \n'); return result; } //+--------------------------------------------------- //| 字符串转成日期类型 //| 格式 MM/dd/YYYY MM-dd-YYYY YYYY/MM/dd YYYY-MM-dd //+--------------------------------------------------- function StringToDate(DateStr) { var converted = Date.parse(DateStr); var myDate = new Date(converted); if (isNaN(myDate)) { //var delimCahar = DateStr.indexOf('/')!=-1?'/':'-'; var arys= DateStr.split('-'); myDate = new Date(arys[0],--arys[1],arys[2]); } return myDate; }
发表评论
-
js技巧
2010-06-16 21:50 750事件源对象 event.srcElement.tagName ... -
js操作table(创建并设置样式)与图片控制
2010-06-16 21:29 1435一、操作table Html代码 .Ta ... -
js得到窗口/对象尺寸/刷新父页面的多种方法
2010-06-16 21:27 1407网页可见区域宽:document.body.clientWid ... -
js之类型转换与引用类型(Boolean/Number/String)
2010-06-16 21:26 1237一、类型转换 1.转换成 ... -
js之本地对象(Array/Date)
2010-06-16 21:26 931一、Array类 1.创建Array对 ... -
js之自定义对象/URI编码
2010-06-16 21:25 1012一、定义对象 1.对象初始化器方式 格式:objectNam ... -
js之正则表达式
2010-06-16 21:22 944一、RegExp 1.定义 Java ... -
javascript keyCode
2010-06-16 21:21 691keycode 8 = BackSpace BackS ... -
JavaScript实用小技巧
2010-06-16 21:17 9111. oncontextmenu="window.e ... -
jQuey语法总结和注意事项
2010-06-16 20:51 10461、关于页面元素的引用 通过jquery的$()引 ... -
Javascript技巧
2010-05-19 16:39 6801. oncontextmenu="window.e ... -
ajax 夸域取数据
2010-05-09 18:46 808package org.test; impor ... -
页面校验通用js
2010-04-25 22:06 812/***************************** ... -
字符串转换成json的三种方式
2010-04-10 09:29 966使用ajax的开发项目过程中,经常需要将json格式的字符串返 ... -
js function汇总
2010-04-10 08:55 9521。无对话框关闭窗口 Js代码 wind ... -
JQuery技巧总结(转载)
2009-12-07 10:03 759一、简介 1.1、概述 随 ... -
JSEclipse 在线安装
2009-11-30 16:30 1249JSEclipse是个Eclipse下的免费Javascrip ... -
精通 JS正则表达式
2009-11-16 12:14 737正则表达式可以: •测试字符串的某个模式。例如,可以对一个输入 ... -
js创建表格
2009-09-28 16:17 2482添加table <table class=& ... -
子窗体于父窗体之间值的传递
2009-09-28 16:15 1143其中window.parent相对于框架(iframe )来 ...
相关推荐
日期时间脚本库方法列表
JavaScript日期控件是一种在网页上实现用户交互式选择日期的工具,它可以帮助用户方便地输入或选择日期,常用于表单填写、事件预订等场景。本篇将详细讲解一款名为"js成品日期控件"的资源,包括其源码结构、使用方法...
此外,`My97DatePicker`可能是一个流行的JavaScript日期选择插件,它提供了更丰富的日期时间选择功能,比如日期范围选择、自定义样式等,可以与这个时钟控件配合使用,提供更完善的日期时间管理体验。 总之,通过...
总结来说,"日历时间JavaScript"是JavaScript在Web开发中处理日期和时间的一种方式,`laydate`是一个实用的JavaScript日期插件,它提供了一套完善的API和丰富的样式,使得在网页上实现交互式日历控件变得简单易行。...
本文将深入探讨如何创建一个既美观又实用的时间选择控件,主要基于JSP、JavaScript以及自定义JS实现。 首先,我们要明确这个“最漂亮”的时间选择控件是由前人的经验基础上进一步完善的。这意味着我们在设计时需要...
- **丰富的工具函数**:如同Python的内置模块一样,Vtils可能提供了各种实用的工具函数,比如字符串处理、数组操作、日期时间操作、类型检查、深度拷贝等。 - **模块化设计**:为了支持摇树优化,Vutil可能采用了...
在本场景中,"等待下班js倒计时代码"指的是一个使用JavaScript编写的程序,用于显示剩余到下班时间的倒计时。这种类型的代码通常会结合服务器时间或者用户本地时间来计算距离特定下班时间(例如18:00)的剩余分钟或...
【标题】"js有小时和分钟的日历"指的是在网页应用中使用JavaScript实现的一个功能完善的日历组件,它不仅能够显示日期,还包含了小时和分钟的选择,为用户提供更精确的时间选择能力。 【描述】"绝对不忽悠人很有用...
FlexoCalendar.js是一款高效实用的JavaScript插件,它基于广泛使用的jQuery库,为网页开发者提供了构建功能丰富的日历、周历和月历组件的能力。这款插件以简洁的蓝色调设计,赋予用户友好的视觉体验,同时具备高度的...
JavaScript简易年历源码是一种基于Web的交互式日历组件,设计简洁且功能实用,尤其适合那些希望在网页上添加日期选择功能的开发者。这个年历源码具有良好的可定制性和扩展性,允许用户根据自身需求进行二次开发和...
`jsUtils` 是一个用于存储JavaScript实用工具函数的库,特别强调其作为实验性项目的性质。这个库旨在为开发者提供一系列便捷的工具,帮助他们更高效地编写JavaScript代码。尽管这些函数可能还在不断测试和完善中,但...
由于JavaScript的数据类型系统相对灵活,但同时也可能导致类型错误,convert.js这样的库就显得尤为实用。 描述中的"convert.js一个简单的JavaScript转换库"进一步确认了这是一个轻量级的解决方案,旨在为开发者提供...
【标题】"JS实现的日历"是一个利用JavaScript编程语言创建的实用日历组件。这个程序设计得既高效又用户友好,可以直接集成到任何网页中,为用户提供方便的日期选择功能,而无需进行复杂的代码调整。 【描述】所提及...
2. **日期对象**:JavaScript的内置Date对象是处理日期和时间的关键。我们可以创建一个新的Date实例,如`new Date()`,获取当前日期,或者通过传入参数设置特定日期。Date对象提供了许多方法,如`getDate()`获取月份...
从描述中我们可以知道,这个日历控件已经被封装得相当完善,开发者只需要简单地引入相关的CSS和JS文件,就可以在网页中快速实现一个美观的日历组件,而且还有示例代码供参考,对于初学者来说非常友好。 在实际应用...
【标题】"wannianli[百度万年历日历JS版]" 提供的是一个基于JavaScript实现的日历组件,这个组件来源于百度,旨在为网页应用提供功能完善的日期选择功能。JavaScript,作为前端开发的主要语言之一,常用于创建交互式...
JavaScript日历控件是网页开发中常用的一种交互元素,它能帮助用户在Web应用中方便地选择日期。本文将深入探讨“比较不错的js日历控件”,并基于提供的压缩包文件,分析其特点、功能以及可能的应用场景。 首先,这...
综上所述,`phpjs`是一个非常实用的前端开源库,它通过JavaScript实现了大量PHP函数,使得前端开发者可以在浏览器端复用PHP的功能,提高了开发效率和应用的用户体验。同时,其开源的性质也促进了开发者之间的合作与...
在这个名为“Vue-Web-Template”的项目中,开发者利用Vue.js搭建了一个基础的Web应用模板,结合了Vuex状态管理库、Lodash.js实用工具库以及Moment.js日期处理库,为项目提供了完善的基础设施。 首先,Vue.js的核心...