javascript – 下划线中的Partials模板(就像在handlebars中)?

我有这样的骨干模型
var PeopleModel = Backbone.Model.extend({
defaults: {              
    "people": [
          { "username": "alan","firstName": "Alan","lastName": "Johnson","phone": "1111","email": "alan@test.com" },{ "username": "allison",firstName: "Allison","lastName": "House","phone": "2222","email": "allison@test.com" },{ "username": "ryan","firstName": "Ryan","lastName": "Carson","phone": "3333","email": "ryan@test.com" },{ "username": "ed","firstName": "Edward","lastName": "Feild","phone": "4444","email": "ed@test.com" },{ "username": "phil","firstName": "Philip","lastName": "Doom","phone": "5555","email": "phil@test.com" },{ "username": "gerald","firstName": "Gerald","lastName": "Butler","phone": "6666","email": "gerald@test.com" }
    ],"company": {"name": "Random Corp."},"country": "England"
}

});

以下是我的模板

<script id="people-template" type="text/x-handlebars-template">
{{#each people}}
  {{> person}}
{{/each}}
</script>

<script id="person-partial" type="text/x-handlebars-template">
 <div class="person">
    <h2>{{fullName}} </h2>
    <div class="phone">{{phone}}</div>
   <div class="email"><a href="mailto:{{email}}">{{email}}</a></div>    
 </div>

这是我如何实现部分使用handlebars.js.

我的问题

我们有类似的东西,我的意思是部分的下划线模板引擎?

2.如何在underscore.js模板引擎中实现部分

解决方法

不,在Underscore的模板中没有本地的部分支持.但是,您可以将<%...%&gt ;;特别是你可以调用自己的函数,这样你可以添加一些部分的东西,而不会有困难.你可以有一个这样的模板:
<script id="people-template" type="text/x-handlebars-template">
    <% _(people).each(function(person) { %>
      <%= partial('person',person) %>
    <% }) %>
</script>

然后在窗口中添加一个部分函数

window.partial = function(which,data) {
    var tmpl = $('#' + which + '-partial').html();
    return _.template(tmpl)(data);
};

演示:http://jsfiddle.net/ambiguous/HDuj5/9/

这不是像{{> …}}在Handlebars,但是Underscore的模板是一个非常薄的包装JavaScript本身,并限制了你的一些.您可以使用命名空间来避免将事情直接放在窗口中,也可以使用{variable: ...} option to _.template和包装器来设置您的标准助手.

相关文章

前言 做过web项目开发的人对layer弹层组件肯定不陌生,作为l...
前言 前端表单校验是过滤无效数据、假数据、有毒数据的第一步...
前言 图片上传是web项目常见的需求,我基于之前的博客的代码...
前言 导出Excel文件这个功能,通常都是在后端实现返回前端一...
前言 众所周知,js是单线程的,从上往下,从左往右依次执行,...
前言 项目开发中,我们可能会碰到这样的需求:select标签,禁...