-
Notifications
You must be signed in to change notification settings - Fork 650
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
<await>
tag doesn't render correctly with client-reorder
when inside <table>
element
#2242
Comments
Curiously, this works as expected in the Marko Playground |
@vwong this is a somewhat known issue. I'm not sure of a good way to work around it. The way I would recommend only putting the reordered FYI the reason this works in the playground is because the playground lies to you. It actually does a client render (which does technically support async) and client renders don't go through the browsers html parser and avoids any kind of hydration issue. I am very open to discussing ways we could potentially work around this although I'm not sure we can. |
So, the problem is the placeholder, not its replacement…
Would it be possible to copy the implementation of `await`, as something
like `await-tr` locally, and get it to use `tr` instead of `span` as the
wrapping element, so the browser handles it properly?
…On Sat, 1 June 2024, 1:31 pm Dylan Piercey, ***@***.***> wrote:
@vwong <https://github.com/vwong> this is a somewhat known issue.
I'm not sure of a good way to work around it.
In essence the reason this is problematic is because when a browser parser
a <table> it will insert elements (eg wrapping <tbody>, <tr>, <td> etc).
The way client-reorder works currently is by inserting a dummy element to
wrap your ***@***.***> content, so that Marko can find and replace that
content after. In your case this ends up with markup something like
<span><tr><td> which the browser attempts to fix and Marko doesn't
recover from (hydration issue).
I would recommend only putting the reordered <await>'s inside of the <td>
or outside of the table altogether (sadly).
FYI the reason this works in the playground is because the playground lies
to you. It actually does a client render (which does technically support
async) and client renders don't go through the browsers html parser and
avoids any kind of hydration issue.
—
Reply to this email directly, view it on GitHub
<#2242 (comment)>,
or unsubscribe
<https://github.com/notifications/unsubscribe-auth/AADR6AODQANDYPYUZOYO4K3ZFE6ADAVCNFSM6AAAAABITQPTVCVHI2DSMVQWIX3LMV43OSLTON2WKQ3PNVWWK3TUHMZDCNBTGI3DKOBWGU>
.
You are receiving this because you were mentioned.Message ID:
***@***.***>
|
Marko Version: 5.35.0
Details
I'm trying to run
<await client-reorder>
inside a<table>
to await each row independently.Expected Behavior
<table>
is rendered correctly, the same way as withoutclient-reorder
.Actual Behavior
Both placeholder and result remains in the HTML.
Steps to Reproduce
See reproduction
The text was updated successfully, but these errors were encountered: