Angular 2 change event on every keypress

后端 未结 11 1409
说谎
说谎 2020-11-27 09:36

The change event is only called after the focus of the input has changed. How can I make it so that the event fires on every keypress?



        
11条回答
  •  一整个雨季
    2020-11-27 10:13

    The (keyup) event is your best bet.

    Let's see why:

    1. (change) like you mentioned triggers only when the input loses focus, hence is of limited use.
    2. (keypress) triggers on key presses but doesn't trigger on certain keystrokes like the backspace.
    3. (keydown) triggers every time a key is pushed down. Hence always lags by 1 character; as it gets the element state before the keystroke was registered.
    4. (keyup) is your best bet as it triggers every time a key push event has completed, hence this also includes the most recent character.

    So (keyup) is the safest to go with because it...

    • registers an event on every keystroke unlike (change) event
    • includes the keys that (keypress) ignores
    • has no lag unlike the (keydown) event

提交回复
热议问题