0

我遇到了handlebars.js 的问题。也许这完全是微不足道的,但我在车把方面也是全新的。所以......这是我的 index.html 中的示例代码,如下所示:

    <!DOCTYPE html>

    <!--[if lt IE 7]>      <html class="no-js lt-ie9 lt-ie8 lt-ie7"> <![endif]-->
    <!--[if IE 7]>         <html class="no-js lt-ie9 lt-ie8"> <![endif]-->
    <!--[if IE 8]>         <html class="no-js lt-ie9"> <![endif]-->
    <!--[if gt IE 8]><!--> <html class="no-js"> <!--<![endif]-->
        <head>

            <meta charset="utf-8">
            <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
            <title></title>

            <meta name="description" content="">
            <meta name="viewport" content="width=device-width">
            <script data-main="scripts/main" src="scripts/require.js"></script>
            <!-- Place favicon.ico and apple-touch-icon.png in the root directory -->

            <link rel="stylesheet" href="css/normalize.css">
            <link rel="stylesheet" href="css/main.css">
            <script src="scripts/modernizr-2.6.2.min.js"></script>


            <script src='scripts/content.js'></script>
            <script src='scripts/handlebars-1.0.0-rc.4.js'></script>
            <script src="//ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>
            <script>window.jQuery || document.write('<script src="scripts/jquery-1.9.1.min.js"><\/script>')</script>
            <script src="scripts/plugins.js"></script>
            <script src="scripts/main.js"></script>


        </head>

        <body>

            <!--[if lt IE 7]>
                <p class="chromeframe">You are using an <strong>outdated</strong> browser. Please <a href="http://browsehappy.com/">upgrade your browser</a> or <a href="http://www.google.com/chromeframe/?redirect=true">activate Google Chrome Frame</a> to improve your experience.</p>
            <![endif]-->

            <!-- Add your site or application content here -->

<script id="some-template" type="text/x-handlebars-template">
      <table>
        <thead>
          <th>Username</th>
          <th>Real Name</th>
          <th>Email</th>
        </thead>
        <tbody>
          {{#users}}
            <tr>
              <td>{{username}}</td>
              <td>{{firstName}} {{lastName}}</td>
              <td>{{email}}</td>
            </tr>
          {{/users}}
        </tbody>
      </table>
    </script>


        </body>
    </html>

还有这个 content.js 文件,其中包含简单的 javascript 代码,但它仍然不起作用。如果你们中的任何人可以建议或提供解决方案,我将非常感激。先感谢您

 var source   = $("#some-template").html();
  var template = Handlebars.compile(source);
  var data = { users: [
      {username: "alan", firstName: "Alan", lastName: "Johnson", email: "alan@test.com" },
      {username: "allison", firstName: "Allison", lastName: "House", email: "allison@test.com" },
      {username: "ryan", firstName: "Ryan", lastName: "Carson", email: "ryan@test.com" }
    ]};
  $("#content-placeholder").html(template(data));

此致

4

2 回答 2

1

除非您创建了一个名为“users”的自定义块帮助器迭代器,否则以下块将不会执行,这就是为什么当您尝试呈现模板时什么都看不到的原因。

不正确的块助手迭代器:

{{#users}}
   ...
{{/users}}

根据您在示例中提供的数据,您应该执行以下操作:

正确的块助手迭代器:

{{#each user}}
   My name is {{this.firstname}} {{this.lastname}} and my email is {{this.email}}.
{{/each}}

您可以参考Handlebarsjs文档站点上的块助手。一开始可能有点难以消化,但稍微玩一下,你就会开始学习 Handlebarsjs 的一些功能。

于 2013-06-04T02:51:48.667 回答
0
  1. 在导入 jQuery之前,您正在导入“content.js”脚本。

  2. 该脚本中的代码应该包含在一个 jQuery“就绪”处理程序中:

     $(function() {
        var source   = $("#some-template").html();
        var template = Handlebars.compile(source);
        var data = { users: [
          {username: "alan", firstName: "Alan", lastName: "Johnson", email: "alan@test.com" },
          {username: "allison", firstName: "Allison", lastName: "House", email: "allison@test.com" },
          {username: "ryan", firstName: "Ryan", lastName: "Carson", email: "ryan@test.com" }
        ]};
        $("#content-placeholder").html(template(data));
     });
    

第一个问题会导致在浏览器控制台中记录错误。这是您应该始终首先检查的内容。

于 2013-05-29T19:07:29.353 回答