You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
Frontend developers are familiar with the concept of layouts, so let's align with that. This feature would replace the concept of "renderers" and the render module would be no more. At the same time, we'll remove support for having multiple renderers/layouts in one file (which is what the render module encouraged). That feature requires complex parsing of the render module to determine which statements are used by which renderers. It'll be nice to remove that complexity.
How are layouts defined?
Layouts are defined with the defineLayout function and typically exported with export default. Layouts can optionally wrap the defineLayout call with an arrow function so the layout can be customized by the developer for specific routes.
From the routes module, the developer can…
set the default layout for all routes or a set of routes (via setLayout call)
set the layout of a single route (via chained method call, or maybe the route config?)
What do layouts do?
Layouts control…
the <html> and <head> elements (via object or string)
how the route module is rendered to HTML
how the page is hydrated (if at all)
the Vite config for each route
Layouts can use the RenderRequest object to influence any of its behavior. Access of route props (via req.props) within the layout's render method is tracked, so only the props needed for hydration are sent to the client. If the layout has no hydrator, then route props are never sent to the client.
Example layout module
exportdefault(options)=>defineLayout((req)=>{return{// Can be a string or object.head: {title: "",language: "",description: "",viewport: {},meta: [{property: "og:title",content: ""}],styles: [{media: "",innerText: ""}],scripts: [{src: "",async: true},{innerText: ""}],links: [{rel: "icon",href: "/favicon.svg"}],},// Provide a Vite config.config: async()=>(awaitimport("./config")).default(options),// Provide a client hydration function.hydrator: ()=>import("./hydrator"),// Render a route module.render(module,{ nested }){// Prop access is observed, so only props needed for hydration are sent to the client.constlayout=<div>{req.props.foo}</div>;// The `nested` flag tells the layout to skip stringification.returnnested ? layout : renderToHtml(layout);},};});
The text was updated successfully, but these errors were encountered:
Frontend developers are familiar with the concept of layouts, so let's align with that. This feature would replace the concept of "renderers" and the render module would be no more. At the same time, we'll remove support for having multiple renderers/layouts in one file (which is what the render module encouraged). That feature requires complex parsing of the render module to determine which statements are used by which renderers. It'll be nice to remove that complexity.
How are layouts defined?
Layouts are defined with the
defineLayout
function and typically exported withexport default
. Layouts can optionally wrap thedefineLayout
call with an arrow function so the layout can be customized by the developer for specific routes.From the routes module, the developer can…
setLayout
call)What do layouts do?
Layouts control…
<html>
and<head>
elements (via object or string)Layouts can use the
RenderRequest
object to influence any of its behavior. Access of route props (viareq.props
) within the layout'srender
method is tracked, so only the props needed for hydration are sent to the client. If the layout has nohydrator
, then route props are never sent to the client.Example layout module
The text was updated successfully, but these errors were encountered: