如何在 JavaScript 中正确读取对象
How to read object properly in JavaScript
我是编程新手,最近开始学习 Javascript,我在做的几个练习中出现了一个问题。我在网站上搜索了更多信息,但没有找到解决我的问题的方法。我提前为我的英语不好道歉,如果这不是正确的地方或正确的方式来问这个问题,因为这是我在 Whosebug 中的第一个 post。
目前正在练习 HTML 个模板。假设代码是正确的,我不确定我哪里错了。将代码加载到浏览器和 Handlebars 中时出现错误:"Error: You must pass a string or Handlebars AST to Handlebars.compile. You passed undefined"。我尝试调试,发现当我尝试从 date
对象中获取值时,它返回未定义的值。在之前的练习中有一个类似的问题,我试图读取 JSON 对象但没有设法解析它并再次返回未定义。你能帮帮我吗,我被这个问题困了一段时间了。
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>
document.getElementsByClassName
returns 一组元素,而不是单个元素 - 因为页面上的多个元素可以具有相同的 class.
您可能想要使用 id
而不是 class:
<script id="container-template" type="text/x-handlebars-template">
var htmlTemplate = document.getElementById('container-template').innerHTML;
我是编程新手,最近开始学习 Javascript,我在做的几个练习中出现了一个问题。我在网站上搜索了更多信息,但没有找到解决我的问题的方法。我提前为我的英语不好道歉,如果这不是正确的地方或正确的方式来问这个问题,因为这是我在 Whosebug 中的第一个 post。
目前正在练习 HTML 个模板。假设代码是正确的,我不确定我哪里错了。将代码加载到浏览器和 Handlebars 中时出现错误:"Error: You must pass a string or Handlebars AST to Handlebars.compile. You passed undefined"。我尝试调试,发现当我尝试从 date
对象中获取值时,它返回未定义的值。在之前的练习中有一个类似的问题,我试图读取 JSON 对象但没有设法解析它并再次返回未定义。你能帮帮我吗,我被这个问题困了一段时间了。
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>
document.getElementsByClassName
returns 一组元素,而不是单个元素 - 因为页面上的多个元素可以具有相同的 class.
您可能想要使用 id
而不是 class:
<script id="container-template" type="text/x-handlebars-template">
var htmlTemplate = document.getElementById('container-template').innerHTML;