How to get text of an input text box during onKeyPress?

前端 未结 12 1597
遥遥无期
遥遥无期 2020-11-28 05:12

I am trying to get the text in a text box as the user types in it (jsfiddle playground):

相关标签:
12条回答
  • 2020-11-28 05:47

    Handling the input event is a consistent solution: it is supported for textarea and input elements in all contemporary browsers and it fires exactly when you need it:

    function edValueKeyPress() {
        var edValue = document.getElementById("edValue");
        var s = edValue.value;
    
        var lblValue = document.getElementById("lblValue");
        lblValue.innerText = "The text box contains: " + s;
    }
    <input id="edValue" type="text" onInput="edValueKeyPress()"><br>
    <span id="lblValue">The text box contains: </span>

    I'd rewrite this a bit, though:

    function showCurrentValue(event)
    {
        const value = event.target.value;
        document.getElementById("lblValue").innerText = value;
    }
    <input id="edValue" type="text" onInput="showCurrentValue(event)"><br>
    The text box contains: <span id="lblValue"></span>

    0 讨论(0)
  • 2020-11-28 05:52

    Try to concatenate the event charCode to the value you get. Here is a sample of my code:

    <input type="text" name="price" onkeypress="return (cnum(event,this))" maxlength="10">
    <p id="demo"></p>
    

    js:

    function cnum(event, str) {
        var a = event.charCode;
        var ab = str.value + String.fromCharCode(a);
        document.getElementById('demo').innerHTML = ab;
    }
    

    The value in ab will get the latest value in the input field.

    0 讨论(0)
  • 2020-11-28 05:55

    By using event.key we can get values prior entry into HTML Input Text Box. Here is the code.

    function checkText()
    {
      console.log("Value Entered which was prevented was - " + event.key);
      
      //Following will prevent displaying value on textbox
      //You need to use your validation functions here and return value true or false.
      return false;
    }
    <input type="text" placeholder="Enter Value" onkeypress="return checkText()" />

    0 讨论(0)
  • 2020-11-28 05:57

    easy...

    In your keyPress event handler, write

    void ValidateKeyPressHandler(object sender, KeyPressEventArgs e)
    {
        var tb = sender as TextBox;
        var startPos = tb.SelectionStart;
        var selLen= tb.SelectionLength;
    
        var afterEditValue = tb.Text.Remove(startPos, selLen)
                    .Insert(startPos, e.KeyChar.ToString()); 
        //  ... more here
    }
    
    0 讨论(0)
  • 2020-11-28 05:57

    So there are advantages and disadvantages to each event. The events onkeypress and onkeydown don't retrieve the latest value, and onkeypress doesn't fire for non-printable characters in some browsers. The onkeyup event doesn't detect when a key is held down for multiple characters.

    This is a little hacky, but doing something like

    function edValueKeyDown(input) {
        var s = input.value;
    
        var lblValue = document.getElementById("lblValue");
        lblValue.innerText = "The text box contains: "+s;
    
        //var s = $("#edValue").val();
        //$("#lblValue").text(s);    
    }
    
    <input id="edValue" type="text" onkeydown="setTimeout(edValueKeyDown, 0, this)" />
    

    seems to handle the best of all worlds.

    0 讨论(0)
  • 2020-11-28 06:02

    I normally concatenate the field's value (i.e. before it's updated) with the key associated with the key event. The following uses recent JS so would need adjusting for support in older IE's.

    Recent JS example

    document.querySelector('#test').addEventListener('keypress', function(evt) {
        var real_val = this.value + String.fromCharCode(evt.which);
        if (evt.which == 8) real_val = real_val.substr(0, real_val.length - 2);
        alert(real_val);
    }, false);
    

    Support for older IEs example

    //get field
    var field = document.getElementById('test');
    
    //bind, somehow
    if (window.addEventListener)
        field.addEventListener('keypress', keypress_cb, false);
    else
        field.attachEvent('onkeypress', keypress_cb);
    
    //callback
    function keypress_cb(evt) {
        evt = evt || window.event;
        var code = evt.which || evt.keyCode,
            real_val = this.value + String.fromCharCode(code);
        if (code == 8) real_val = real_val.substr(0, real_val.length - 2);
    }
    

    [EDIT - this approach, by default, disables key presses for things like back space, CTRL+A. The code above accommodates for the former, but would need further tinkering to allow for the latter, and a few other eventualities. See Ian Boyd's comment below.]

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