从JQuery模板迁移后,有没有人可以帮助了解如何呈现JSRender模板?
使用旧的JQuery Template系统,我的HTML页面中有以下内容:
<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>
然后从一个单独的js文件开始 - 摘自此文件,其中$( '#pageTmpl1' ).tmpl( pageData ).appendTo( this.$el );
是关键部分:
_layout : function() {
this._setLayoutSize();
for( var i = 0; i <= this.pagesCount - 2; ++i ) {
var $page = this.$pages.eq( i ),
pageData = {
theClass1 : 'page1',
theContentFront1 : $page.html(),
theContentBack1 : ( i !== this.pagesCount ) ? this.$pages.eq( i + 1 ).html() : '',
theStyle1 : 'z-index: ' + ( this.pagesCount - i ) + ';left: ' + ( this.windowProp.width / 2 ) + 'px;',
theContentStyleFront1 : 'width:' + this.windowProp.width + 'px;',
theContentStyleBack1 : 'width:' + this.windowProp.width + 'px;'
};
if( i === 0 ) {
pageData.theClass1 += ' cover1';
}
else {
pageData.theContentStyleFront1 += 'left:-' + ( this.windowProp.width / 2 ) + 'px';
if( i === this.pagesCount - 2 ) {
pageData.theClass1 += ' cover-back1';
}
}
$( '#pageTmpl1' ).tmpl( pageData ).appendTo( this.$el );
}
this.$pages.remove();
this.$flipPages = this.$el.children( 'div.page1' );
this.flipPagesCount = this.$flipPages.length;
this._adjustLayout( ( this.state === undefined ) ? this.currentPage : this.state );
},
有谁知道如何更改上面的基本设置才能迁移到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>
为:
<script id="pageTmpl" type="text/x-jsrender">
<div class="{{:theClass}}" style="{{:theStyle}}">
<div class="front">
<div class="outer">
<div class="content" style="{{:theContentStyleFront}}">
<div class="inner">{{>theContentFront}}</div>
</div>
</div>
</div>
<div class="back">
<div class="outer">
<div class="content" style="{{:theContentStyleBack}}">
<div class="inner">{{>theContentBack}}</div>
</div>
</div>
</div>
</div>
在index.html中,来自:
$( '#pageTmpl' ).tmpl( pageData ).appendTo( this.$el );
为:
$("this.$el").html(
$("#pageTmpl").render(pageData)
);
在jquery.flips.js。
您可以提供有关其原因的任何建议,我们将不胜感激。
答案 0 :(得分:2)
以下是使用 jQuery模板的页面:
jquery-tmpl/demos/step-by-step/.../0_local-data-source.html。
以下是使用 jsRender 的等效页面:
jsrender/demos/step-by-step/01_inserting-data.html(Code here)。
所以你看到了
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
基于字符串的渲染是better perf与JsRender的一个原因。
关于模板标签的映射方式,以下是一些基本标签:
jQuery模板:
${name}
{{html synopsis}}
{{if languages}}...{{else subtitles}}...{{else}}...{{/if}}
{{each languages}}...{{/each}}
<强> jsRender 强>