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

本文介绍如何使用JavaScript将日期格式化为符合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.youkuaiyun.com/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);
		}
	});
};
 

 

 

 

在magic-api 2.1.1 中 修改下列代码使其能够正常运行 import java.util.Date; import java.text.SimpleDateFormat; import com.newinterface.crmslab.Util.AesUtil; // 配置 AES 解密密钥 var aesKey = "JDH#7PESHPOWKX5!"; // 根据加密类型处理数据 var secStr = body.secStr; var secType = body.secType; var decryptedData = String; if (secType == 0) { // 未加密 decryptedData = secStr; } else if (secType == 1) { // AES 解密 decryptedData = AesUtil.decryptData(secStr,aesKey); } var dataMap = JSON.parse(decryptedData); // 服务项目列表JSON var serviceItemsJson = "[]"; serviceItemsJson = typeof dataMap.serviceItemList === 'string' ? serviceItemList : JSON.parse(dataMap.serviceItemList); // 当前时间 var now = new Date(); // 构建参数对象 var params = { sampleId: dataMap.sampleId, sampleBarcode: dataMap.sampleBarcode || null, userName: dataMap.userName || '', userPhone: dataMap.userPhone || null, credentialType: dataMap.credentialType || null, credentialNo: dataMap.credentialNo || null, userGender: dataMap.userGender || null, userAge: dataMap.userAge || null, samplingTechnician: dataMap.samplingTechnician || null, samplingTime: dataMap.samplingTime || null, orderingPhysician: dataMap.orderingPhysician || null, orderingTime: dataMap.orderingTime ||null, serviceItemList: serviceItemsJson, serviceItemName: dataMap.serviceItemName || '', storeId: dataMap.storeId || '', storeName: dataMap.storeName || null, appointmentStartTime: dataMap.appointmentStartTime ||null, userMarriage: dataMap.userMarriage || null, userBirth: dataMap.userBirth || null, coreStatus: dataMap.coreStatus, subStatus: dataMap.subStatus || null, bizProcessType: dataMap.bizProcessType, timestamp: dataMap.timestamp || 0, outerPatientId: dataMap.outerPatientId || null, partnerSourceOrderId: dataMap.partnerSourceOrderId, storeOperatingSystemSource: dataMap.storeOperatingSystemSource, createTime: now }; // 重复数据查询 var exists = db.jd.selectInt(""" SELECT COUNT(1) FROM SAMPLEINFO WHERE SAMPLEID = #{dataMap.get('sampleId')} """) // 执行数据库操作 var saveResult = false; if (exists > 0) { // 更新现有记录 db.jd.table('sampleinfo').primary('sampleId').update(params); } else { // 插入新记录 db.jd.table('sampleinfo').primary('sampleId').insert(params); }
最新发布
11-14
<think>我们已经在之前讨论过使用JSP实现日期选择的方法,现在用户再次提问,需要参考站内引用内容。 根据引用[1]和[3]:我们可以使用JSTL的fmt标签来格式日期。根据引用[4]:提到了日期控件,并且输入框设置了readonly属性,用户点击后弹出选择框。 用户的需求是:在JSP页面上实现一个字段,点击该字段可以弹出日期选择器进行选择。 结合之前的回答和引用内容,我们可以提供以下方案: 方案一:使用HTML5的input type="date"(简单,但需要考虑浏览器兼容性) 方案二:使用JavaScript实现自定义日期选择器(兼容性好,但需要自己编写代码) 由于引用[4]提到输入框设置为readonly,并且需要弹出选择框,这里我们重点实现方案二(自定义日期选择器),同时结合引用[3]的日期格式化。 但是,我们也可以考虑使用现有的JavaScript库(如jQuery UI日期选择器)?但是用户要求只用JSP,也就是不要依赖外部JS库?然而,JSP本质上是生成HTML,所以我们可以使用纯JavaScript实现。 考虑到用户要求只用JSP,我们可以理解为在JSP页面中编写代码,包括HTML、CSS和JavaScript,而不引入外部库。 因此,我们将实现一个简单的自定义日期选择器。 步骤: 1. 创建一个文本输入框,设置为只读,当点击时弹出日期选择面板。 2. 创建一个日期选择面板(div),初始为隐藏,当点击输入框时显示在输入框下方。 3. 在面板中动态生成日历(包括年月切换和日期表格)。 4. 点击日期后,将日期值填入输入框,并隐藏面板。 注意:这里我们将使用JavaScript来实现日历的动态生成,包括月份切换。 由于这是一个较为复杂的功能,我们将分步骤实现: 第一步:创建输入框和日历容器 第二步:编写显示日历的函数(包括生成指定年月的日历) 第三步:实现月份切换功能 第四步:处理日期选择事件 为了简化,我们只实现公历日历,并且不考虑时间部分。 另外,根据引用[3],我们可以使用JSTL格式日期,但是这里我们是在前端选择日期,所以不需要后端格式化,但如果我们从后端获取日期值并显示,则可以使用fmt标签。 下面是一个简化版的实现: 由于代码较长,我们将分块编写。 注意:这个自定义日历没有使用任何外部库,纯JavaScript实现。 我们将实现以下功能: - 显示当前月的日历 - 可以切换到上个月和下个月 - 点击日期后填充到输入框,并隐藏日历 日期格式:我们将使用“yyyy-MM-dd”格式。 下面是完整的JSP页面代码示例: </think>### JSP 实现字段点击选择日期的方法 在 JSP 中实现日期选择功能,结合引用内容提供两种实用方案: --- #### 方案 1:使用 HTML5 原生日期控件(推荐) ```jsp <%@ page contentType="text/html;charset=UTF-8" language="java" %> <!DOCTYPE html> <html> <head> <title>日期选择</title> </head> <body> <form> <label>选择日期:</label> <!-- HTML5 原生日期控件 --> <input type="date" name="selectedDate" min="2023-01-01" max="2025-12-31"> <!-- 可选日期范围限制 --> </form> </body> </html> ``` **特点**: 1. 浏览器自动提供日期选择 UI(桌面端/移动端均兼容) 2. 提交时自动验证格式,无需额外代码 [^1] 3. 支持日期范围限制(`min`/`max`属性) 4.格式为 `yyyy-MM-dd`,可直接存入数据库 [^5] --- #### 方案 2:自定义日期选择器(兼容旧浏览器) ```jsp <%@ page contentType="text/html;charset=UTF-8" language="java" %> <%@ taglib prefix="fmt" uri="http://java.sun.com/jsp/jstl/fmt" %> <!-- 引用[1][3] --> <!DOCTYPE html> <html> <head> <title>自定义日期选择</title> <style> #datePicker { display: none; position: absolute; border: 1px solid #ccc; padding: 10px; background: white; z-index: 100; } .date-cell { display: inline-block; width: 30px; height: 30px; text-align: center; line-height: 30px; cursor: pointer; } .date-cell:hover { background: #f0f0f0; } </style> <script> // 显示日期选择器 function showPicker(inputId) { const picker = document.getElementById("datePicker"); picker.style.display = "block"; picker.dataset.target = inputId; // 关联目标输入框 // 动态生成当月日历(简化示例) const today = new Date(); const daysInMonth = new Date( today.getFullYear(), today.getMonth() + 1, 0 ).getDate(); let html = `<div>${today.getFullYear()}年${today.getMonth()+1}月</div>`; for (let i = 1; i <= daysInMonth; i++) { html += `<div class="date-cell" onclick="selectDate(${i})">${i}</div>`; } picker.innerHTML = html; } // 选择日期 function selectDate(day) { const picker = document.getElementById("datePicker"); const targetInput = document.getElementById(picker.dataset.target); const date = new Date(); // 格式化为 yyyy-MM-dd const formattedDate = `${date.getFullYear()}-${(date.getMonth()+1).toString().padStart(2,'0')}-${day.toString().padStart(2,'0')}`; targetInput.value = formattedDate; picker.style.display = "none"; } </script> </head> <body> <label>开始日期:</label> <input type="text" id="startDate" onclick="showPicker('startDate')" readonly> <!-- 引用[4] --> <label>结束日期:</label> <input type="text" id="endDate" onclick="showPicker('endDate')" readonly> <div id="datePicker"></div> <%-- 后端日期格式化示例(若从数据库获取) --%> <% java.util.Date dbDate = new java.util.Date(); // 模拟数据库日期 request.setAttribute("dbDate", dbDate); %> <p>数据库日期: <fmt:formatDate value="${dbDate}" pattern="yyyy-MM-dd" /> <!-- 引用[3] --> </p> </body> </html> ``` **关键实现**: 1. 输入框设置 `readonly` 强制用户使用选择器 [^4] 2. 点击输入框触发 `showPicker()` 动态生成日历 3. 使用 `fmt:formatDate` 格式化后端日期显示 [^1][^3] 4. 选择日期后自动格式化为 `yyyy-MM-dd` 格式 --- ### 后端处理示例 ```jsp <%@ page import="java.text.SimpleDateFormat" %> <%@ page import="java.util.Date" %> <% // 获取前端提交的日期 String dateStr = request.getParameter("selectedDate"); // 转换为Date对象 SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd"); Date selectedDate = sdf.parse(dateStr); // 数据库操作(引用[5]示例扩展) Connection conn = db.DbConn.getConn(); String sql = "INSERT INTO orders(order_date) VALUES(?)"; PreparedStatement pstmt = conn.prepareStatement(sql); pstmt.setDate(1, new java.sql.Date(selectedDate.getTime())); pstmt.executeUpdate(); %> ``` --- ### 最佳实践建议 | 情景 | 推荐方案 | 说明 | |------|----------|------| | 现代浏览器 | HTML5 原生控件 | 零代码、移动端友好 | | 旧版浏览器 | 自定义选择器 | 需手动实现 UI | | 数据库日期展示 | JSTL fmt 标签 | 统一格式化显示 [^1][^3] | | 企业级系统 | 结合两者 | 使用特性检测回退方案 | > 提示:实际开发中,可通过 `<%= new Date().getYear() + 1900 < 2015 %>` 检测旧浏览器,动态切换方案
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值