-
-
Notifications
You must be signed in to change notification settings - Fork 964
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Input field with name "value" or buttons without "type" break the app in conditional rendering #1477
Comments
For the first error: If you are interested in fixing this, the error looks like it is coming from here when the desktop event is deserialized from json. Specifically, the value field in the json is an empty This means that the event was serialized wrong in the interpreter here or here. For the second error: This static HTML also reloads the page if you click the button: <!DOCTYPE html>
<html>
<body>
<h1>The button form attribute</h1>
<form action="/action_page.php" method="get" id="nameform">
<label for="fname">First name:</label>
<input type="text" id="fname" name="fname"><br><br>
<label for="lname">Last name:</label>
<input type="text" id="lname" name="lname">
<button>Submit</button>
</form>
<p>The button below is outside the form element, but still part of the form.</p>
</body>
</html> The default type of a button is submit. If you would like to not submit, you can set the type of the button to "button": <!DOCTYPE html>
<html>
<body>
<h1>The button form attribute</h1>
<form action="/action_page.php" method="get" id="nameform">
<label for="fname">First name:</label>
<input type="text" id="fname" name="fname"><br><br>
<label for="lname">Last name:</label>
<input type="text" id="lname" name="lname">
<button type="button">Submit</button>
</form>
<p>The button below is outside the form element, but still part of the form.</p>
</body>
</html> |
Hi @ealmloff Adding |
prevent_default only applies to elements that have an event listener with the same type as the event you are preventing on them. It also accepts a string for the type of event to prevent default on. We would like to remove prevent default and add a prevent_default method to the event object to make this more clear, but synchronously preventing events across the wry boundary is difficult. form {
onsubmit: |evt| evt.prevent_default()
} |
@ealmloff Great explanation! So the suggestion of Jonathan would be to create some sort of React Synthetic Events. |
Kind of, we already have synthetic events (becoming a bit less synthetic with #1402). You can stop a synthetic event from bubbling with stop_propagation, but you cannot prevent the browser behavior with a function. The issue here is that all communication with wry (the webview library that Dioxus uses) is asynchronous. We need to create a synchronous way to run the rust code that was triggered because of the event and then potentially cancel the browser's event before it continues bubbling to other elements |
This is fixed! By #1974 |
Problem
I'm running a desktop app using
dx serve
on a MacOS. When I conditionally render a form that contains a field with name equals to"value"
, after clicking "Send" the application panics.I noticed another bug in forms. If I have a
button
with notype
attribute, after clicking "Send" the application removes every component. Looks like it does a form submission. Here is the snippet:Steps To Reproduce
Panics after clicking "Send":
Removes everything after clicking "Send":
Expected behavior
I expect in both cases the form to hide.
Environment:
master
1.72.0
MacOS
desktop
Questionnaire
The text was updated successfully, but these errors were encountered: