日期字段中的自动斜杠使用javascript保持永久性

时间:2017-04-20 01:26:04

标签: javascript date field

我可以在日期字段中添加自动斜杠。但是当我点击退格键时,我需要反斜杠保持原样。

var keycode = event.which,
    value = $(current).val(),
    position1 = 3,
    position2 = 6;
if((value.length === (position1 - 1)) || 
   (value.length === (position2 - 1))){
    if (keycode === 8) {
       value = value + '/';
    }
}

1 个答案:

答案 0 :(得分:0)

您可以尝试jsfiddle

中的answer
var format = "mm/dd/yyyy";
var match = new RegExp(format
    .replace(/(\w+)\W(\w+)\W(\w+)/, "^\\s*($1)\\W*($2)?\\W*($3)?([0-9]*).*")
    .replace(/m|d|y/g, "\\d"));
var replace = "$1/$2/$3$4"
    .replace(/\//g, format.match(/\W/));

function doFormat(target)
{
    target.value = target.value
        .replace(/(^|\W)(?=\d\W)/g, "$10")   // padding
        .replace(match, replace)             // fields
        .replace(/(\W)+/g, "$1");            // remove repeats
}

$("input[name='birthdate']:first").keyup(function(e) {
   if(!e.ctrlKey && !e.metaKey && (e.keyCode == 32 || e.keyCode > 46))
      doFormat(e.target)
});

更新

尝试使用HTML5

fiddle