-
-
Notifications
You must be signed in to change notification settings - Fork 367
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
Nested Mustache Partials Rendering #706
Comments
OK, this was not too hard as a first cut. The main thing to get my head around was the idea that the each View Template that is processed by the Execute method has its own list of partials. I initially I thought that the rendering process was throwing that away between calls to the Execute method, although further investigation reveals the underlying SynMustache has a cache which is active across the calls to Execute as well as active across requests. So this should result in a good performance if the template/partial has already been loaded. With that in mind, I check to see if the partial template has been loaded (internally the SynMustache engine does this, but I am saving a call to the disk - which in a busy server is going to be happening many times per second. I've also taken the decision to make the Partials collection a class field so that the optimisation above persists across the request. I.e. previously a Controller line of code like Unfortunately for each request, the template still has to be loaded from disk, because the underlying SynMustacheCache uses a hash of the contents as the index into its cache, so you can't check the cache to see if it has been loaded without reading if from the disk. Chicken and Egg as they say. However the work involved in parsing the template is avoided because the SynMustacheCache can detect it is already present so does not process it. Without wanted to get side tracked I offer the proposed changes. And note that i have not yet merged in the suggested changes for the Mustache Helpers from earlier
|
A simple (slightly naive) improvement will cache the templates for the first time they are accessed during a request, so if they are accessed subsequently in the same request the code will not need to hit the disk. This will have no effect across requests, as the cache is owned by the instance of the engine which is discarded between requests. I could look at a threadsafe cache later.
|
Hi David, did you tried the repo version? As a side note (not directly related to this issue, but it worth mention in this context) now you can use the following methods to handle SSV:
|
I've taken a look but I don't see the repo version handling more than one level of Partials. |
I have some mustache templates that can be called in a variety of contexts, to support full page rendering and HTMX (partial page) rendering.
For the initial (full) page rendering, we have a page composed of 3 html fragments: page_header, contents, page_footer. When the page is initially loaded the code will be like
Inside the contents template we have some static data followed by a table. The table template sets up an html table, including the thead and then includes another template (content_data) to pull in the rows of data.
The content_data template iterates over the data collection and then attempts to pull in another template (table_footer) to render the footer for the table. (This table footer is used all over the application so it makes sense to keep it as a separate template.)
However as the rendering is now three levels deep the table_footer template is never processed as the framework's ViewEngine Execute method does not allow more than one level of nesting.
Note that we have another controller method that the HTMX calls that only renders out the content_data template, as it is performing an in place replacement of the table data. Because the table_footer template is now only one level deep in this context it gets rendered.
I'm thinking we need to refactor the Execute method to be able to firstly build the data models and then recursively call the template, processing each partial as it is declared.
Any other thoughts before I take a look at this.
The text was updated successfully, but these errors were encountered: