ThinkChat2.0新版上线,更智能更精彩,支持会话、画图、阅读、搜索等,送10W Token,即刻开启你的AI之旅 广告
## 2.12 自定义布局 布局可以通过Beetl提供的include,layout 以及模板变量来完成。模板变量能完成复杂的布局 - 采用layout include ```javascript <% //content.html内容如下: layout("/inc/layout.html"){ %> this is 正文 .......... <% } %> ``` 如上一个子页面将使用layout布局页面,layout 页面内容如下 ```javascript <% include("/inc/header.html"){} %> this is content:${layoutContent} this is footer: ``` layoutContent 是默认变量,也可以改成其他名字,具体请参考layout标签函数 全局变量总是能被布局用的页面所使用,如果布局页面需要临时变量,则需要显示的传入,如: ```javascript <% var user= model.user; include("/inc/header.html",{title:'这是一个测试页面',user:user}){} %> ``` 这样,title和user成为全局变量,能被header.html 及其子页面引用到 - 继承布局:采用模板变量和include ```javascript <% var jsPart = { %> web页面js部分 <% }; %> <% var htmlPart = { %> web页面html部分 <% }; include("/inc/layout.html",{jsSection:jsPart,htmlSection:htmlPart}){} %> ``` layout.html页面如下: ```html <body> <head> ${jsSection} </head> <body> ....... ${htmlSection} </body> ``` > include, includeUrl,includeJSP,还有includeFragement都是Beetl提供的include系列标签函数,includeUrl,includeJSP考虑到需要WEB环境,并没有内置,需要手工注册,参考IncludeJSPTag.java,IncludeUrlTag.java