mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 14:05:37 +02:00
Merge pull request #5954 from open-sausages/pulls/4.0/ssviewer-include-docs
Clarified <% include %> use in SS4 (fixes #5952)
This commit is contained in:
commit
1000e94337
@ -49,12 +49,17 @@ text-based format.
|
|||||||
SilverStripe templates are plain text files that have `.ss` extension and located within the `templates` directory of
|
SilverStripe templates are plain text files that have `.ss` extension and located within the `templates` directory of
|
||||||
a module, theme, or your `mysite` folder.
|
a module, theme, or your `mysite` folder.
|
||||||
|
|
||||||
By default, templates will have the same name as the class they are used to render. So, your Page class will
|
By default, templates will have the same name as the class they are used to render. So, your `Page` class will
|
||||||
be rendered with the `templates/Page.ss` template.
|
be rendered with the `templates/Page.ss` template.
|
||||||
|
|
||||||
When the class has a namespace, the namespace will be interpreted as subfolder within the `templates` path. For, example, the class `SilverStripe\Control\Controller` will be rendered with the
|
When the class has a namespace, the namespace will be interpreted as a subfolder within the `templates` path.
|
||||||
|
For example, the class `SilverStripe\Control\Controller` will be rendered with the
|
||||||
`templates/SilverStripe/Control/Controller.ss` template.
|
`templates/SilverStripe/Control/Controller.ss` template.
|
||||||
|
|
||||||
|
If you are using template "types" like `Layout` or `Includes`, these are just folders which you need
|
||||||
|
to append to your template file location. One exception is the `<% include %>` template tag,
|
||||||
|
where you need to leave out the `Includes/` folder.
|
||||||
|
|
||||||
## Variables
|
## Variables
|
||||||
|
|
||||||
Variables are placeholders that will be replaced with data from the [DataModel](../model/) or the current
|
Variables are placeholders that will be replaced with data from the [DataModel](../model/) or the current
|
||||||
@ -204,13 +209,15 @@ Within SilverStripe templates we have the ability to include other templates usi
|
|||||||
will be searched for using the same filename look-up rules as a regular template. However in the case of the include tag
|
will be searched for using the same filename look-up rules as a regular template. However in the case of the include tag
|
||||||
an additional `Includes` directory will be inserted into the resolved path just prior to the filename.
|
an additional `Includes` directory will be inserted into the resolved path just prior to the filename.
|
||||||
|
|
||||||
E.g.
|
:::ss
|
||||||
|
<% include SideBar %> <!-- chooses templates/Includes/Sidebar.ss -->
|
||||||
|
<% include MyNamespace/SideBar %> <!-- chooses templates/MyNamespace/Includes/Sidebar.ss -->
|
||||||
|
|
||||||
* `<% include SideBar %>` will include `templates/Includes/Sidebar.ss`
|
When using subfolders in your template structure
|
||||||
* `<% include MyNamespace/SideBar %>` will include `templates/MyNamespace/Includes/Sidebar.ss`
|
(e.g. to fit with namespaces in your PHP class structure), the `Includes/` folder needs to be innermost.
|
||||||
|
|
||||||
Note that in SilverStripe 3, you didn't have to specify a namespace in your `include` tag, as the template engine didn't
|
:::ss
|
||||||
use namespaces. As of SilverStripe 4, the template namespaces need to match the folder structure of your template files.
|
<% include MyNamespace/SideBar %> <!-- chooses templates/MyNamespace/Includes/Sidebar.ss -->
|
||||||
|
|
||||||
The `include` tag can be particularly helpful for nested functionality and breaking large templates up. In this example,
|
The `include` tag can be particularly helpful for nested functionality and breaking large templates up. In this example,
|
||||||
the include only happens if the user is logged in.
|
the include only happens if the user is logged in.
|
||||||
|
@ -84,7 +84,7 @@ Templates are now much more strict about their locations. You can no longer put
|
|||||||
folder and have it be found. Case is now also checked on case-sensitive filesystems.
|
folder and have it be found. Case is now also checked on case-sensitive filesystems.
|
||||||
|
|
||||||
Either include the folder in the template name (`renderWith('MyEmail.ss')` => `renderWith('emails/MyEmail.ss')`),
|
Either include the folder in the template name (`renderWith('MyEmail.ss')` => `renderWith('emails/MyEmail.ss')`),
|
||||||
move the template into the correct directory, or both.
|
move the template into the correct directory, or both. This also affects `<% include %>` statements in templates.
|
||||||
|
|
||||||
When using `<% include %>` template tag you should continue to leave out the `Includes` folder.
|
When using `<% include %>` template tag you should continue to leave out the `Includes` folder.
|
||||||
`<% include Sidebar %>` will match only match `Includes/Sidebar.ss`, not `Sidebar.ss`.
|
`<% include Sidebar %>` will match only match `Includes/Sidebar.ss`, not `Sidebar.ss`.
|
||||||
|
Loading…
Reference in New Issue
Block a user