我是JavaScript新手,我想这样做:我有一个带有对象的数组(一个对象有标题,封面,作者和评级),我想用这些对象填充div,每个div一个div宾语。但我不知道如何在不为每个div创建新元素(h1,p,img)的情况下这样做。这是我的第一次尝试:
// Display the books
var container = document.getElementById('books-container');
function displayBooks(arr) {
arr.forEach(function(item) {
var bookRow = document.createElement('div');
bookRow.className = "row";
container.appendChild(bookRow);
var imgColumn = document.createElement('div');
imgColumn.className = "large-4 columns";
bookRow.appendChild(imgColumn);
var imgBook = document.createElement('img');
imgBook.className = "book-img";
imgColumn.appendChild(imgBook);
var bookColumn = document.createElement('div');
bookColumn.className = "large-8 columns";
bookRow.appendChild(bookColumn);
var title = document.createElement('h3');
title.innerText = item.title;
bookColumn.appendChild(title);
var author = document.createElement('p');
author.innerText = item.author;
bookColumn.appendChild(author);
var rating = document.createElement('p');
rating.innerText = item.rating;
bookColumn.appendChild(rating);
var input = document.createElement('input');
input.type = "checkbox";
input.className = "checked";
bookColumn.appendChild(input);
var wishBtn = document.createElement('button');
wishBtn.innerText = "Add to wishlist";
bookColumn.appendChild(wishBtn);
var hr = document.createElement('hr');
bookRow.appendChild(hr);
});
};
displayBooks(books);

但我认为有一种更简单的方法。
我不能使用任何库。这是一个家庭作业,我只能使用JavaScript本身提供的功能和对象。
答案 0 :(得分:3)
这就像Handlebars等类似的模板引擎非常方便:您可以定义一个具有您想要的模板,然后让引擎使用对象作为基础来渲染模板。
例如,使用把手你可以做这样的事情(从他们的网站无耻地复制):
<script id="entry-template" type="text/x-handlebars-template">
<div class="entry">
<h1>{{title}}</h1>
<div class="body">
{{body}}
</div>
</div>
</script>
然后在你的代码中:
var source = $("#entry-template").html();
var template = Handlebars.compile(source);
arr.forEach(function(item) {
container.insertAdjacentHTML("beforeend", template(item));
});
下一版本的JavaScript,&#34; ES6&#34;,将模板字符串作为语言的一部分。
您已经(间接)在评论中说您不能使用Handlebars。这个函数很乐意使用${name}
形式的占位符字符串,并用相关的对象属性替换所有出现的占位符。它将无法替换任何不由对象属性表示的标记:
function cheapTemplateEval(str, obj) {
Object.keys(obj).forEach(function(name) {
str = str.replace(RegExp("\\$\\{" + name + "\\}", "g"), obj[name]);
});
return str;
}
注意这假设对象上的属性名称只包含在正则表达式中不特殊的字符。
直播示例:
function cheapTemplateEval(str, obj) {
Object.keys(obj).forEach(function(name) {
str = str.replace(RegExp("\\$\\{" + name + "\\}", "g"), obj[name]);
});
return str;
}
var str = "<p>Hi ${name}, I'm a really ${adjectives} template!</p>";
document.body.insertAdjacentHTML(
"beforeend",
cheapTemplateEval(str, {
name: "Joe",
adjectives: "nifty and simple"
})
);
&#13;
答案 1 :(得分:0)
我会通过添加原始HTML来实现这一点。它可能有点难看,但它比在这种情况下逐个元素做得更清晰。
var container = document.getElementById('container')
var books = [
{title: 'Catch-22',
author: 'Joseph Heller'
},
{title: 'The Road',
author: 'Cormac McCarthy'
}
];
function bookItem(item) {
return "<h1>" + item.title + "</h1><p>" + item.author + "</p><br />"
}
books.forEach(function(book) {
var new_div = document.createElement('div')
new_div.innerHTML = bookItem(book)
container.appendChild(new_div)
})