-
-
Notifications
You must be signed in to change notification settings - Fork 145
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
How to update a rendered element? #304
Comments
Make sure that your |
Thanks, that was also the direction I was trying to move in. I had changed my component to instead of receiving a slice of What's the "vecty" way of creating a component that accepts child elements / components? |
Turns out I missed a component. After changing my components to look like this:
It now works. But the markup is getting super unwieldy. Is this the recommended way? It does not feel intuitive.. sadly the intuitive approach is evidently error prone. |
Also have to wonder what this does for previously initialized structs. eg. if I set |
I struggled with this when I was trying to get it to work. Have you looked at the todomvc example. vecty/example/todomvc/components/pageview.go Lines 171 to 179 in 41ffb63
This renders a list of properties vs. state type ItemView struct {
vecty.Core
SomePropField `vecty:"prop"`
SomeStateField
} When an
|
I see. So basically Vecty wants you to completely separate the rendering code from the state management code? I guess that makes sense, and is likely somewhere where most devs would end up anyway after the prototyping phase. It does still feel quite error prone though. Appreciate the insights! I'm at least unblocked for now. For what it's worth I'd consider this the only part of vecty so far that I'd like to see some improvement on, everything else has been great! And to be fair it's not that this part is "bad", it's just not intuitive and prone to error. |
By the way, can anyone tell me what this panic achieves? It seems disabling the panic makes the code function exactly the way I had assumed it would. Though I'm guessing it will create some type of breakage in other areas that I haven't reached? |
It might be worth having a read of the following discussion |
@VinceJnz Thanks, that's a useful read. Is implied in your response that the mechanic that this panic guards for is specifically this prop vs state mechanic? It feels like a steep price to pay, surely there's better ways of addressing this use-case. |
fwiw I ended up working around this issue with the following helper:
This was influenced by other vecty projects I found that were using similar helpers. Hopefully this type of workaround won't be required once vecty goes stable. |
Due to lack of documentation I'm working off of examples, issues and backwards engineering. Sadly I feel like the issue of updating already rendered elements isn't easily discerned through any of those channels.
From the example code I found that I probably want to use
vecty.Rerender(elem)
. But so far any attempt I give this results in the following error:I find this error hard to understand. Is it telling me that once rendered an item cannot be rendered again? And if so, how am I meant to update rendered elements? I'm guessing there's a detail I'm missing.
The todo example doesn't seem to be doing anything fancy, I'm not sure what I'm doing wrong.
For what it's worth, here's an excerpt of the code I'm working with:
The text was updated successfully, but these errors were encountered: