如何在JavaScript

时间:2016-08-12 19:19:20

标签: javascript handlebars.js javascript-objects

我是编程新手,最近开始学习Javascript,我有一个问题出现在我做的几个练习中。我在网站上搜索了更多信息,但没有找到解决我问题的方法。我提前为我糟糕的英语道歉,如果这不是正确的地方或正确的方式提出这个问题,因为这是我在Stackoverflow中的第一篇文章。

目前正在练习HTML模板。假设代码是正确的,我不确定我错在哪里。将代码加载到浏览器和Handlebars中会给我一个错误:“错误:您必须将字符串或Handlebars AST传递给Handlebars.compile。您传递了undefined”。我尝试调试并看到当我尝试从date对象获取值时,它会返回undefined。在上一个练习中有一个类似的问题,我试图读取JSON对象,并没有设法解析它并再次返回undefined。你能帮助我吗,我一直坚持这个问题。

var data = {
  animals: [{
    name: 'Lion',
    url: 'https://susanmcmovies.files.wordpress.com/2014/12/the-lion-king-wallpaper-the-lion-king-2-simbas-pride-4685023-1024-768.jpg'
  }, {
    name: 'Turtle',
    url: 'http://www.enkivillage.com/s/upload/images/a231e4349b9e3f28c740d802d4565eaf.jpg'
  }, {
    name: 'Dog'
  }, {
    name: 'Cat',
    url: 'http://i.imgur.com/Ruuef.jpg'
  }, {
    name: 'Dog Again'
  }]
}

window.onload = function() {
  var htmlTemplate = document.getElementsByClassName('container-template').innerHTML;
  var template = Handlebars.compile(htmlTemplate);

  for (let x of data.animals) {
    if (x.hasOwnProperty('url')) { //x.url
      x.hasUrl = true;
    } else {
      x.hasUrl = false;
    }
  }

  document.getElementsByClassName('container').innerHTML = template(data);
}
<!DOCTYPE html>

<html>

<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <meta http-equiv="X-UA-Compatible" content="ie=edge">
  <title>Animals & Batman</title>
</head>

<body>

  <div class="container">
  </div>

  <script class="container-template" type="text/x-handlebars-template">
    <h1>Animals</h1>
    {{#each animals}} 
      {{#if hasUrl}}
          <li>
              <a href="{{url}}">See a {{name}}</a>
          </li>
      {{else}}
          <li>
              <a href="http://cdn.playbuzz.com/cdn/3170bee8-985c-47bc-bbb5-2bcb41e85fe9/d8aa4750-deef-44ac-83a1-f2b5e6ee029a.jpg">No link for {{name}}, here is Batman!</a>
          </li>
      {{/if}} 
    {{/each}}
  </script>

  <script src="../handlebars-v4.0.5.js" charset="utf-8"></script>
  <script src="../jquery-3.1.0.js" charset="utf-8"></script>
  <script src="./main.js" charset="utf-8"></script>
</body>

</html>

1 个答案:

答案 0 :(得分:2)

document.getElementsByClassName返回一个元素数组,而不是一个元素 - 因为页面上的多个元素可以具有相同的类。

您可能想要的是使用id而不是类:

<script id="container-template" type="text/x-handlebars-template">

var htmlTemplate = document.getElementById('container-template').innerHTML;