Javascript Input Text Masking without Plugin

前端 未结 2 1375
星月不相逢
星月不相逢 2020-12-16 18:39

I want to mask the text in an input box without changing the actual value. I can not use any plugins.

I am currently doing this - but as you can see the issue is tha

相关标签:
2条回答
  • 2020-12-16 19:03

    or also

    <input type="text" onkeypress="handleMask(event, 'data: 99/99/9999 99:99 999 ok')" placeholder="data:  ok" size=40>
    

    with

    function handleMask(event, mask) {
        with (event) {
            stopPropagation()
            preventDefault()
            if (!charCode) return
            var c = String.fromCharCode(charCode)
            if (c.match(/\D/)) return
            with (target) {
                var val = value.substring(0, selectionStart) + c + value.substr(selectionEnd)
                var pos = selectionStart + 1
            }
        }
        var nan = count(val, /\D/, pos) // nan va calcolato prima di eliminare i separatori
        val = val.replace(/\D/g,'')
    
        var mask = mask.match(/^(\D*)(.+9)(\D*)$/)
        if (!mask) return // meglio exception?
        if (val.length > count(mask[2], /9/)) return
    
        for (var txt='', im=0, iv=0; im<mask[2].length && iv<val.length; im+=1) {
            var c = mask[2].charAt(im)
            txt += c.match(/\D/) ? c : val.charAt(iv++)
        }
    
        with (event.target) {
            value = mask[1] + txt + mask[3]
            selectionStart = selectionEnd = pos + (pos==1 ? mask[1].length : count(value, /\D/, pos) - nan)
        }
    
        function count(str, c, e) {
            e = e || str.length
            for (var n=0, i=0; i<e; i+=1) if (str.charAt(i).match(c)) n+=1
            return n
        }
    }
    
    0 讨论(0)
  • 2020-12-16 19:15

    You need two inputs

    Two inputs should get the job done. One input will contain the masked text and the other will be a hidden input that contains the real data.

    <input type="text" name="masknumber">
    <input type="text" name="number" style="display:none;">
    

    The way I approached the masking is to build a function for both masking and unmasking the content so everything stays uniform.

    $("input[name='masknumber']").on("keyup change", function(){
            $("input[name='number']").val(destroyMask(this.value));
        this.value = createMask($("input[name='number']").val());
    })
    
    function createMask(string){
        return string.replace(/(\d{2})(\d{3})(\d{2})/,"$1-$2-$3");
    }
    
    function destroyMask(string){
        return string.replace(/\D/g,'').substring(0,8);
    }
    

    Working JSFiddle

    0 讨论(0)
提交回复
热议问题