Javascript 语法更改-从JQuery模板迁移到JsRender
在从JQuery模板迁移之后,有人能帮助我们如何呈现JSRender模板吗 使用旧的JQuery模板系统,我的HTML页面中有以下内容:Javascript 语法更改-从JQuery模板迁移到JsRender,javascript,jquery,jquery-templates,jsrender,Javascript,Jquery,Jquery Templates,Jsrender,在从JQuery模板迁移之后,有人能帮助我们如何呈现JSRender模板吗 使用旧的JQuery模板系统,我的HTML页面中有以下内容: <script id="pageTmpl1" type="text/x-jquery-tmpl"> <div class="${theClass1}" style="${theStyle1}"> <div class="front1">
<script id="pageTmpl1" type="text/x-jquery-tmpl">
<div class="${theClass1}" style="${theStyle1}">
<div class="front1">
<div class="outer1">
<div class="content1" style="${theContentStyleFront1}">
<div class="inner1">{{html theContentFront1}}</div>
</div>
</div>
</div>
<div class="back1">
<div class="outer1">
<div class="content1" style="${theContentStyleBack1}">
<div class="inner1">{{html theContentBack1}}</div>
</div>
</div>
</div>
</div>
有人知道为了迁移到JSRender,我必须如何修改上面的基本设置吗
编辑:
谢谢你的回复
为了给我的问题提供一些背景,这里有两个例子;第一个使用jQuery模板,第二个(带有建议的更改)使用JSRender
尽管遵循所指示的语法变化,但最终没有出现期望的结果(在第二种情况下),没有错误
所做的更改来自:
<script id="pageTmpl" type="text/x-jquery-tmpl">
<div class="${theClass}" style="${theStyle}">
<div class="front">
<div class="outer">
<div class="content" style="${theContentStyleFront}">
<div class="inner">{{html theContentFront}}</div>
</div>
</div>
</div>
<div class="back">
<div class="outer">
<div class="content" style="${theContentStyleBack}">
<div class="inner">{{html theContentBack}}</div>
</div>
</div>
</div>
</div>
</script>
致:
在jquery.flips.js中
如果您能提供任何关于这一点的建议,我们将不胜感激 这是一个使用jQuery模板的页面:
下面是使用jsRender的等价页面:
() 你看到了吗 jQuery模板:
$("#movieTemplate").tmpl(movies).appendTo("#movieList");
映射到:
jsRender
$("#movieList").html(
$("#movieTemplate").render(movies)
);
事实上,JsRender不使用DOM进行渲染
因此,您也可以将上述内容写成:
var html = $("#movieTemplate").render(movies); // Render to string
$("#movieList").html(html); // Insert in DOM
或者你可以写:
var compiledTemplate = $.templates("#movieList"); // Compile template
var html = compiledTemplate.render(movies); // Render to string
$("#movieList").html(html); // Insert in DOM
基于字符串的呈现是使用JsRender的原因之一
关于模板标记的映射方式,以下是一些基本标记:
jQuery模板:
$("#movieTemplate").tmpl(movies).appendTo("#movieList");
${name}
{{html大纲}
{{if languages}}…{{else subtitles}}…{{{else}}…{{/if}}
{{each languages}}…{{/each}
$("#movieList").html(
$("#movieTemplate").render(movies)
);
(请参阅){{:name}
(参见){{>概要}
{{if languages}}…{{else subtitles}}…{{{else}}…{{{/if}}
(此处无更改:请参阅)
(请参阅){{for languages}}…{{/for}
var html = $("#movieTemplate").render(movies); // Render to string
$("#movieList").html(html); // Insert in DOM
var compiledTemplate = $.templates("#movieList"); // Compile template
var html = compiledTemplate.render(movies); // Render to string
$("#movieList").html(html); // Insert in DOM