- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
如果输入数据与yyyy/mm/dd
格式不匹配,我想删除它!我尝试了以下但只删除字母和特殊字符...
例如。
20144 -> must remove last 4
2014// -> must remove last /
2014/01/123 -> must remove last 3
$("input").on("keyup", function() {
console.log(this.value);
this.value = this.value.replace(/[^(\d{4})\/(\d{1,2})\/(\d{1,2})]/g, '');
});
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<input type="text">
最佳答案
一旦你真正分解了你想要的逻辑,策略实际上非常简单。因此,您希望将用户输入强制转换为 YYYY/MM/DD
格式。我们可以一步一步地做到这一点:
/
字符。您现在得到一个数组。YYYY
、MM
和 DD
。我们将忽略后面的任何片段,因为它们不是有效日期的一部分。这可以通过在数组上使用 .slice(0,3)
来完成。0
处,您有年份片段。使用 .substring(0,4)
将其 trim 为最多 4 个字符1
或 2
处,分别有月/日片段。使用 .substring(0,2)
将其 trim 为最多 2 个字符.join('/')
将结果数组重新连接起来。//
。只需使用正则表达式 .replace(/\/(\/)+/, '/') 来 trim 它们
您会注意到,在我的逻辑中,我没有包含填充数字,例如。将天数从 1
转换为 01
。当用户输入时你不能这样做,因为你永远不知道用户是想输入一位还是两位数字。如果您想要这样做,您将必须重新解析输入onblur
,因为此时您知道用户已完成输入。
请参阅下面的概念验证:
$('input').on('keyup', function() {
var valueParts = this.value.split('/');
if (!valueParts.length) {
return;
}
// Only keep the first 3 elements of array
valueParts = valueParts.slice(0, 3);
// Substring array (keep first 4 characters for year, and first 2 characters for month/day)
var substringCounts = [4, 2, 2];
substringCounts.forEach(function(substringCount, index) {
// If index does not exist in array, skip it
if (!valueParts[index])
return;
valueParts[index] = valueParts[index].substring(0, substringCount);
});
// Join remaining elements
var parsedString = valueParts.join('/');
// Trim extraneous slashes
parsedString = parsedString.replace(/\/(\/)+/, '/');
this.value = parsedString;
});
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<input type="text">
注意:如果您想填充数字,则必须在上面提到的内容之上添加以下逻辑:
// Pad numbers on blur
$('input').on('blur', function() {
var valueParts = this.value.split('/');
if (!valueParts.length) {
return;
}
// Only keep the first 3 elements of array
valueParts = valueParts.slice(0, 3);
// Pad lengths (year to 4 digits, month to 2 digits, day to 2 digits)
var padLengths = [4, 2, 2];
padLengths.forEach(function(padLength, index) {
// If index does not exist in array, skip it
if (!valueParts[index])
return;
valueParts[index] = valueParts[index].padStart(padLength, '0');
});
// Join remaining elements
var parsedString = valueParts.join('/');
// Trim extraneous slashes
parsedString = parsedString.replace(/\/(\/)+/, '/');
this.value = parsedString;
});
考虑到这一点,如果你想将上述两个逻辑结合在一起,你可以抽象出处理“连接剩余元素”和“trim 无关斜杠”的部分。我隐藏了下面的代码片段,因为它非常冗长并且大部分包含与上面提到的相同的逻辑:
// Helper method: joins array using '/' and trims duplicated joining characters
function joinAndTrimSlashes(valueArray) {
// Join remaining elements
var parsedString = valueArray.join('/');
// Trim extraneous slashes
parsedString = parsedString.replace(/\/(\/)+/, '/');
return parsedString;
}
$('input').on('keyup', function() {
var valueParts = this.value.split('/');
if (!valueParts.length)
return;
// Only keep the first 3 elements of array
valueParts = valueParts.slice(0, 3);
// Substring array (keep first 4 characters for year, and first 2 characters for month/day)
var substringCounts = [4, 2, 2];
substringCounts.forEach(function(substringCount, index) {
// If index does not exist in array, skip it
if (!valueParts[index])
return;
valueParts[index] = valueParts[index].substring(0, substringCount);
});
this.value = joinAndTrimSlashes(valueParts);
});
// Pad numbers on blur
$('input').on('blur', function() {
var valueParts = this.value.split('/');
if (!valueParts.length)
return;
// Only keep the first 3 elements of array
valueParts = valueParts.slice(0, 3);
// Pad lengths (year to 4 digits, month to 2 digits, day to 2 digits)
var padLengths = [4, 2, 2];
padLengths.forEach(function(padLength, index) {
// If index does not exist in array, skip it
if (!valueParts[index])
return;
valueParts[index] = valueParts[index].padStart(padLength, '0');
});
this.value = joinAndTrimSlashes(valueParts);
});
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<input type="text">
关于javascript - 如果不是 yyyy/mm/dd 格式,则删除当前输入?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54328656/
我需要使用正则表达式验证格式为 dd/mm/yyyy 的日期字符串。 此正则表达式验证 dd/mm/yyyy,但不验证 31/02/4500 等无效日期: ^(0?[1-9]|[12][0-9]|3[
我正在开发一个小型应用程序,其中我的表有一列,我必须在其中查找所有具有此格式值的记录 'dd/dd/dd' where d 是数字(1-9)。 例如,我想查找具有这种格式的值的数据'18/32/23'
这个问题不太可能对任何 future 的访客有帮助;它只与一个较小的地理区域、一个特定的时间点或一个非常狭窄的情况相关,通常不适用于全世界的互联网受众。如需帮助使此问题更广泛适用,visit the
我想要 dd.d.dd.ddddd 或 dd.d.d.ddddd 类型的数据的正则表达式,每个 d 代表 0-9 之间的数字,正则表达式应代表这两种格式。我正在使用 java 脚本。我尝试了以下代码。
我已经搜索了该网站,但没有找到接近我需要的答案。基本上我的日期正确显示为“2013-05-09”,但我想要的是“2013 年 3 月 19 日”或使其更好“3 月 19 日, 2013 年”。 请向我
我需要使用 C# 更改日期字符串的格式 来自:“06/16/2010”或“16/06/2010” 至:“2010-06-16” 你能帮我实现这个吗 谢谢 最佳答案 如果您已经将它作为 DateTime
我需要转换当前日期,其格式为: MM|dd|yy --- 12|09|11 我需要将格式转换为: MM/dd/yy --12/09/11 当前系统日期分隔符是:
这个问题在这里已经有了答案: 关闭 10 年前。 Possible Duplicate: Extending JavaScript's Date.parse to allow for DD/MM/Y
我在 Access VBA 中使用 Date 语句编码了一些东西。直到本月初它都运行良好,但现在我看到日期已从 dd/mm/yyyy 自动更改格式至 mm/dd/yyyy .有没有其他人遇到过同样的问
我有一个类似“Apr 17 09:32:01”的日期格式,但我想获取数字中的月份... 是否可以使用logstash进行转换? 我尝试使用日期过滤器,但它似乎无法将日期从一种格式转换为另一种格式。 我
这个问题已经有答案了: How to convert string "2011-11-29 12:34:25" to date in "dd-MM-yyyy" format in JAVA (6 个回
我在前端使用了日期选择器,格式为mm/dd/yyyy,并且我在mysql中选择了日期数据类型,然后如何编写代码将其从yyyy/dd/mm转换为mm/使用 jsp 的 dd/yyy。我已经尝试过代码但不
我想将日期字段(格式:dd-mm-yyyy)转换为数据库日期格式。如果输入日期格式等于 dd-mm-yyyy 格式,则将日期转换为 yyyy-mm-dd 格式,否则返回 false。 function
我正在尝试在 JavaScript 中将日期格式从 mm-dd-yyyy 转换为 yyyy-mm-dd 。我尝试下面的代码获取无效日期。 var convertJSDate = function(da
使用 NSDateFormatter 解析日期。下面的日期是 2013 年 5 月 2 日。我得到不同的结果(如下所示)取决于我是否在 dateFormat 字符串中使用“DD”和“dd” NSStr
在 DateFormatter 中使用 DD 和 dd 有什么区别?搜索时,我没有看到明显的差异。一些日期格式文档显示“DD”和“dd”,有些则没有。 我想了解其中的区别以及为什么它会产生下面评论中显
我在表中有一个以MM/DD/YYYY格式存储的日期列。我必须选择相同的日期并以YYYY-MM-DD格式(即XSD日期格式)存储在另一个表中。但是我做不到。我正在使用此查询: select to_dat
我陷入了这样一种情况:我通过“LOAD DATA LOCAL INFILE”从 CSV 文件读取数据并将其存储在 Mysql 表中。 我的表格中的日期列是字符串类型。 如果我的日期格式为'yy/dd/
我有一个带有两个日期字段的 mysql 表。 Startdate 和 Enddate 是字段我需要使用字段在前端显示日期,例如“2014 年 10 月 24 日至 26 日” 我怎样才能做到这一点?
我有 HTML 显示用户对私有(private)用户配置文件页面上表单中的字段的响应。表单上的字段是有条件的,因此其中许多字段永远不会呈现给用户。 HTML 由系统输出,从未呈现给用户的下拉字段会收到
我是一名优秀的程序员,十分优秀!