Skip to content
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

Make Leptos iteration example equivalent of Dioxus iteration example #2191

Merged
merged 1 commit into from
Mar 30, 2024

Conversation

gbj
Copy link
Contributor

@gbj gbj commented Mar 30, 2024

The Dioxus example and Leptos example for iteration given in the README are currently different, both in end-user functionality and in mechanism.

I might be mistaken, but my assumption is that the Dioxus example shows a non-keyed list, i.e., removing the element at index 1 from a 10-element list causes all subsequent elements to update, even though only the text nodes need to diff. This has implications for the behavior of things like CSS elements that are well described elsewhere. The Leptos example shown by comparison is a keyed list.

Similarly, again unless I'm mistaken, updating the value of a counter in the Dioxus example does an O(n) diff of all the values of all rows, whereas the Leptos example shown by comparison updates a single nested signal in an O(1) operation, hence the added complexity of nested signals and disposal.

This isn't to say the non-keyed, diffing approach is bad -- it's probably preferable for most cases! This PR just updates the Leptos example shown by comparison to do the same thing (an indexed list that diffs the value of all rows), which (IMO) makes for a more accurate side-by-side comparison.

(Apologies if I overlooked something, I just put this together in a couple minutes and it's bit late here!)

@jkelleyrtp jkelleyrtp merged commit d77e1eb into DioxusLabs:main Mar 30, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants