语法更改 - 从JQuery模板迁移到JsRender

时间:2014-07-13 11:34:55

标签: javascript jquery jquery-templates jsrender

从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。

  1. http://www.timm.ie/example_jqt/
  2. http://www.timm.ie/example_jsr/
  3. 虽然遵循指示的语法更改,但最终没有出现所需的结果(在第二种情况下),没有错误可以使用。

    所做的更改来自:

            <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。

    您可以提供有关其原因的任何建议,我们将不胜感激。

1 个答案:

答案 0 :(得分:2)

以下是使用 jQuery模板的页面:
jquery-tmpl/demos/step-by-step/.../0_local-data-source.html

以下是使用 jsRender 的等效页面:
jsrender/demos/step-by-step/01_inserting-data.htmlCode 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

  • {{:name}}(见docs
  • {{>synopsis}}(见docs
  • {{if languages}}...{{else subtitles}}...{{else}}...{{/if}}
    (所以这里没有变化:见docs
  • {{for languages}}...{{/for}}(见docs