`
coding1688
  • 浏览: 236812 次
  • 来自: 上海
社区版块
存档分类
最新评论

用JS将输入初始化为当前日期,并且符合java.sql.Date格式

 
阅读更多

用JS将输入初始化为当前日期,并且符合java.sql.Date格式

下面的实现方式,jQuery UI 的 Datepicker 插件能够支持,但不能被 java.sql.Date.valueOf() 方法接受,会抛出异常 java.lang.IllegalArgumentException。

 

    var today = new Date();
    var m = today.getMonth() + 1;
    var d = today.getDate();
    var str = today.getFullYear() + "-" + m + "-" + d;
    $("#source_time").val(str);

 

 

因为 java.sql.Date.valueOf() 只接受 yyyy-mm-dd 格式字符串。

 

javadoc 写道
public static Date valueOf(String s)
Converts a string in JDBC date escape format to a Date value.

 

Parameters:
s - a String object representing a date in in the format "yyyy-mm-dd"
Returns:
java.sql.Date object representing the given date
Throws:
IllegalArgumentException - if the date given is not in the JDBC date escape format (yyyy-mm-dd)
 

所以必须要对月份和日期调整格式,如果只有一位数字,在前面加0。如下所示:

 

    var today = new Date();
    var m = today.getMonth() + 1;
    var mm = m < 10 ? "0" + m : m;
    var d = today.getDate();
    var dd = d < 10 ? "0" + d : d;
    var str = today.getFullYear() + "-" + mm + "-" + dd;
    $("#source_time").val(str);
 

当然,我这里的需求比较死板,固定格式为 yyyy-mm-dd,如果需要灵活的变换格式,可以参考下面的文章

阿坤的BLOG 天地生人,有一人应有一人之业;人生在世,生一日当尽一日之勤

老外写的一个javascript下Date格式化函数 http://blog.csdn.net/akunshenjk/article/details/2539638

PS:发现上面链接的提供的源代码中正则表达式有误,还是看下面的好 http://www.4ucode.com/Study/Topic/1174473

下面贴出代码:

 

Date.prototype.format = function(mask) {
	var d = this;
	var zeroize = function (value, length) {
		if (!length) length = 2;
		value = String(value);
		for (var i = 0, zeros = ''; i < (length - value.length); i++) {
			zeros += '0';
		}
		return zeros + value;
	};	

	// return mask.replace(/"[^"]*"|'[^']*'|/b(?:d{1,4}|m{1,4}|yy(?:yy)?|([hHMstT])/1?|[lLZ])/b/g, function($0) {
        return mask.replace(/"[^"]*"|'[^']*'|\b(?:d{1,4}|m{1,4}|yy(?:yy)?|([hHMstT])\1?|[lLZ])\b/g, function($0) {
		switch($0) {
			case 'd':	return d.getDate();
			case 'dd':	return zeroize(d.getDate());
			case 'ddd':	return ['Sun','Mon','Tue','Wed','Thr','Fri','Sat'][d.getDay()];
			case 'dddd':	return ['Sunday','Monday','Tuesday','Wednesday','Thursday','Friday','Saturday'][d.getDay()];
			case 'M':	return d.getMonth() + 1;
			case 'MM':	return zeroize(d.getMonth() + 1);
			case 'MMM':	return ['Jan','Feb','Mar','Apr','May','Jun','Jul','Aug','Sep','Oct','Nov','Dec'][d.getMonth()];
			case 'MMMM':	return ['January','February','March','April','May','June','July','August','September','October','November','December'][d.getMonth()];
			case 'yy':	return String(d.getFullYear()).substr(2);
			case 'yyyy':	return d.getFullYear();
			case 'h':	return d.getHours() % 12 || 12;
			case 'hh':	return zeroize(d.getHours() % 12 || 12);
			case 'H':	return d.getHours();
			case 'HH':	return zeroize(d.getHours());
			case 'm':	return d.getMinutes();
			case 'mm':	return zeroize(d.getMinutes());
			case 's':	return d.getSeconds();
			case 'ss':	return zeroize(d.getSeconds());
			case 'l':	return zeroize(d.getMilliseconds(), 3);
			case 'L':	var m = d.getMilliseconds();
					if (m > 99) m = Math.round(m / 10);
					return zeroize(m);
			case 'tt':	return d.getHours() < 12 ? 'am' : 'pm';
			case 'TT':	return d.getHours() < 12 ? 'AM' : 'PM';
			case 'Z':	return d.toUTCString().match(/[A-Z]+$/);
			// Return quoted strings with the surrounding quotes removed
			default:	return $0.substr(1, $0.length - 2);
		}
	});
};
 

 

但这篇文章提供的方法,主要适合老外的使用情况,不太符合中国人的要求。稍作修改,如下所示:

 

Date.prototype.format = function(mask) {
	var d = this;
	var zeroize = function (value, length) {
		if (!length) length = 2;
		value = String(value);
		for (var i = 0, zeros = ''; i < (length - value.length); i++) {
			zeros += '0';
		}
		return zeros + value;
	};	

	// return mask.replace(/"[^"]*"|'[^']*'|/b(?:d{1,4}|m{1,4}|yy(?:yy)?|([hHMstT])/1?|[lLZ])/b/g, function($0) {
        return mask.replace(/"[^"]*"|'[^']*'|\b(?:d{1,4}|m{1,4}|yy(?:yy)?|([hHMstT])\1?|[lLZ])\b/g, function($0) {
		switch($0) {
			case 'd':	return d.getDate();
			case 'dd':	return zeroize(d.getDate());
			case 'ddd':	return ['日','一','二','三','四','五','六'][d.getDay()];
			case 'dddd':	return ['星期日','星期一','星期二','星期三','星期四','星期五','星期六'][d.getDay()];
			case 'M':	return d.getMonth() + 1;
			case 'MM':	return zeroize(d.getMonth() + 1);
			case 'MMM':	return ['一','二','三','四','五','六','七','八','九','十','十一','十二'][d.getMonth()];
			case 'MMMM':	return ['一月','二月','三月','四月','五月','六月','七月','八月','九月','十月','十一月','十二月'][d.getMonth()];
			case 'yy':	return String(d.getFullYear()).substr(2);
			case 'yyyy':	return d.getFullYear();
			case 'h':	return d.getHours() % 12 || 12;
			case 'hh':	return zeroize(d.getHours() % 12 || 12);
			case 'H':	return d.getHours();
			case 'HH':	return zeroize(d.getHours());
			case 'm':	return d.getMinutes();
			case 'mm':	return zeroize(d.getMinutes());
			case 's':	return d.getSeconds();
			case 'ss':	return zeroize(d.getSeconds());
			case 'l':	return zeroize(d.getMilliseconds(), 3);
			case 'L':	var m = d.getMilliseconds();
					if (m > 99) m = Math.round(m / 10);
					return zeroize(m);
			case 'tt':	return d.getHours() < 12 ? '上午' : '下午';
			case 'TT':	return d.getHours() < 12 ? '上午' : '下午';
			case 'Z':	return d.toUTCString().match(/[A-Z]+$/);
			// Return quoted strings with the surrounding quotes removed
			default:	return $0.substr(1, $0.length - 2);
		}
	});
};
 

 

 

 

1
1
分享到:
评论

相关推荐

    java.sql.与java.util

    要从`java.util.Date`转换为`java.sql.Date`,可以调用`java.util.Date`的`getTime()`方法获取时间戳,然后用这个时间戳初始化`java.sql.Date`。相反,从`java.sql.Date`转换回`java.util.Date`,只需传入`java.sql....

    java.util.Date与java.sql.Date的区别

    一旦成功,我们就可以使用 `getTime()` 方法从 `java.util.Date` 获取毫秒值,然后用这个值初始化 `java.sql.Date` 对象。 总的来说,`java.util.Date` 是一个通用的日期和时间类,而 `java.sql.Date` 是针对数据库...

    java.lang.IllegalArgumentException Cannot format given Object as a Date

    1. **传入的参数不是日期对象**:如果你尝试用`SimpleDateFormat`的`format()`方法处理非`java.util.Date`、`java.sql.Date`、`java.time.LocalDate`等日期类型的对象,Java会抛出此异常。确保你传递的是正确的日期...

    struts的form不能初始化java.util.Date类型

    然而,有一个常见的问题出现在尝试初始化`java.util.Date`类型的字段时,即“Struts的form不能初始化java.util.Date类型”。这个问题通常是由于日期对象的序列化和反序列化机制导致的,以及Struts默认的数据绑定策略...

    java中时间格式的转换.docx

    在实际开发中,经常需要将`java.util.Date`对象转换为`java.sql.Date`或`java.sql.Timestamp`对象,以便于存储到数据库中。 **示例代码**: ```java import java.sql.Date; import java.util.Date; public ...

    各版本Microsoft.SqlServer.Diagnostics.STrace

    解决Management Studio打开弹错误: “Microsoft.SqlServer.Management.Dmf.PolicyStore”的类型初始值设定项引发异常。 (Microsoft.SqlServer.Dmf) 未能加载文件或程序集“Microsoft.SqlServer.Diagnostics.STrace,...

    Microsoft.SqlServer.Diagnostics.STrace.dll

    “Microsoft.SqlServer.Management.Dmf.PolicyStore”的类型初始值设定项引发异常。 (Microsoft.SqlServer.Dmf) 未能加载文件或程序集“Microsoft.SqlServer.Diagnostics.STrace, Version=10.0.0.0, Culture=...

    Java 之 Date 和 Calendar 实例

    1. `Date()`:构造一个表示当前日期和时间的`Date`对象。 2. `toString()`:将日期转换为字符串形式。 3. `getTime()`:返回从1970年1月1日00:00:00 GMT到当前日期的毫秒数。 4. `setTime(long time)`:设置日期为...

    Microsoft.SqlServer.Diagnostics.STrace

    SQL2008:“Microsoft.SqlServer.Management.Dmf.PolicyStore”的类型初始值设定项引发异常。 未能加载文件或程序集“Microsoft.SqlServer.Diagnostics.STrace, Version=10.0.0.0, Culture=neutral, PublicKeyToken...

    Java程序 实现 显示当前时间

    总的来说,无论你是使用传统的`java.util.Date`和`SimpleDateFormat`,还是选择Java 8的`java.time`API,都可以轻松地在Java程序中获取并显示当前时间。了解这些基础将有助于你在开发中处理日期和时间相关的功能。

    45.java数组动态初始化.zip

    45.java数组动态初始化.zip45.java数组动态初始化.zip45.java数组动态初始化.zip45.java数组动态初始化.zip45.java数组动态初始化.zip45.java数组动态初始化.zip45.java数组动态初始化.zip45.java数组动态初始化.zip...

    java 日期相加减.doc

    创建一个`Date`对象表示当前日期,并使用`SimpleDateFormat`将其格式化为字符串。 ```java Date d = new Date(); SimpleDateFormat df = new SimpleDateFormat("yyyy-MM-dd"); System.out.println("今天的日期...

    java.lang.NullPointerException

    Java.lang.NullPointerException 是 Java 语言中一种常见的异常,它发生在 Java 应用程序尝试使用 null 对象引用时。这种异常通常是由于程序员错误地认为对象已经被初始化或赋值,而实际上对象仍然是 null。 在本文...

    51.java二维数组动态初始化.zip

    51.java二维数组动态初始化.zip51.java二维数组动态初始化.zip51.java二维数组动态初始化.zip51.java二维数组动态初始化.zip51.java二维数组动态初始化.zip51.java二维数组动态初始化.zip51.java二维数组动态初始化....

    java日期转化操作大全.pdf

    Java从JDK 1.0起就提供了处理日期和时间的API,随着版本的迭代,API不断改进,逐渐形成了以java.util.Date、java.util.Calendar以及java.text.DateFormat/SimpleDateFormat为主的日期时间处理体系。 java.util.Date...

    日期插件 jquery-date.js

    3. **配置选项**:`jquery-date.js`提供了丰富的配置项,如日期格式、默认值、禁用日期等,可以通过初始化时传入的对象进行设置。 三、插件功能 1. **日期选择**:用户可以通过下拉菜单选择年、月、日,或者直接...

    java连接sql server2008所需要的jar包

    在Java编程环境中,连接SQL Server 2008数据库通常需要特定的驱动程序,这些驱动程序以Java Archive (JAR)文件的形式存在。标题提到的"java连接sql server2008所需要的jar包"正是提供了这样的驱动,确保Java应用程序...

    javaAPI(SQL)帮助文档

    Java API for SQL是Java编程语言中用于访问和处理关系数据库的标准接口。这个强大的工具集使得开发者能够在Java应用程序中执行SQL语句,管理数据库连接,以及处理结果集。本帮助文档将深入探讨Java SQL API的核心...

    Java 学生信息管理系统

    压缩包内的“studentmanage.sql”文件,即为创建数据库表的SQL脚本,用于初始化数据库。 三、数据库设计 在学生信息管理系统中,数据库设计是关键。通常会包含“学生”、“课程”、“成绩”等表,每个表都有特定的...

Global site tag (gtag.js) - Google Analytics