I can handle the key event in my live view code easily. However, hitting certain keys may trigger some unwanted default action in the browser. For example, hitting “Enter” may trigger a form submit.
I can prevent these default actions using client hooks. I can capture the key event in JS and then call event.preventDefault() before sending the event to my liveview using pushEvent(). Although this works, it is less clean and more complex than doing everything in liveview.
So my questions are:
Can browser’s default actions be prevented directly in LV without using client hooks? I suspect this is not possible.
If it’s not possible, would it make sense to add a LV binding that disables default actions? Something like: phx-prevent-default. Would anybody else find this useful? If not, why?
It boils down to placing a disabled invisible submit button before a visible submit button in the DOM, which will prevent the form from submitting on Enter.
@Xty yes that works thanks. It’s a good old trick However, that requires the ability to modify the form. My use case is a bit different: I’m developing an input component that will be used as a library by others, and I would like the component to be able to say “don’t submit on enter” because it uses the enter key as part of its internal behavior. Hooks work fine for that, and as far as I know, they are the only option for now.