前一篇说了jsrender嵌套循环的使用,在SPA的应用中,广泛使用的一个点就是view模板,使用了SPA之后,每个业务页面不再是独立的html,仅仅是一个segment,所以通常这些segment会被独立的存储,而不是跟demo一样嵌在宿主页面中。因为jsrender的模板本质上就是一个string,所以一般三方库angularjs/backbone.js都提供了加载外部模板的机制。其实原理都一样,差不多都是通过ajax从远程加载,然后缓存在B/S端,在jsrender中,通过类似机制,也可以达到一样的目标。如下所示:
render_seg.html
{ { for #data}}{ {:name}}
- { { for language}}
- { {:#parent.parent.data.name}} is learning { {:title}} { { for scores}} { {:score}} { {/for}} { {/for}}
主页面jsrender_nest_external.html
jsrender nest external demo
其效果和内嵌模板完全相同,不过更加的干净。