-
Notifications
You must be signed in to change notification settings - Fork 11
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
Allow struct initialzation syntax inside attribute #48
Comments
@tachibanayui Hi. But i want to touch on the use of nodes in position of arguments separately: I understand the motivation behind - some users want to implement components with different view branches for different situations. What do you think to instead of providing a way to put node-tree into attribute, give a way to move-out some of attributes into separate pseudo-elements ? So instead of writing <Routes>
<Route path="/" view={<Home/>}/>
<Route path="/other" view={<Other>"children"</Other>} />
<Route path="/*any" view={<>"just text"</>} />
</Routes> One could write: <Routes>
// find first child with "Component.*" syntax
<Route path="/" >
<Route.view>
<Home/>
</Route.view>
</Route>
// or on same node-tree level to make it shorter
// find first sibling with "Component.*" syntax
<Route path="/other" />
<Route.view> <Other>"children"</Other> </Route.view>
// keeping original to compare
<Route path="/*any" view={<>"just text"</>} />
</Routes> |
My original intention is to implement support for transforming values in attribute value positions like the About the readability issue, I used <Route path="/users" view={
<MyCustomComponent my_attr="my_value">
<UserPage/>
</MyCustomComponent>
} />
<Route path="/products"
extra_attrs="extra value here"
view={
<ProductPage
my_attr_1="my_value"
my_attr_2="my_value"
my_attr_3="my_value"
my_attr_4="my_value"
my_attr_5="my_value" />
}
more_extra_args=""
/>
.NET XAML format also uses this syntax to support element nodes inside attributes (properties in xaml) and IMO I also like this syntax. But parsing this syntax is harder for the end user because they have to look ahead inside its children's to find additional attributes and validate them. Also, it is a bit hard to understand the relationship between parent and child when both move-out attributes node and children node are used together, something like React Suspense: <Suspense>
<Suspense.fallback>
<LoadingIndicator />
</Suspense.fallback>
<div>
// Large lines of UI code
</div>
</Suspense> Original: ```rs
<Suspense fallback={<LoadingIndicator />} >
<div>
// Large lines of UI code
</div>
</Suspense> But for your example specifically, breaking out attributes into sub-children nodes is better. However, the ability to transform code inside attribute value allows for more flexibility and parity between rsx and jsx |
Currently, key-value attributes only allow valid
Expr
.Because a
Style
struct is expected here so it could be simplified to:Maybe we could extend
KeyedAttributeValue
to acceptBlock(NodeBlock)
as another variant? This way #14 can be implemented (with a brace):The text was updated successfully, but these errors were encountered: