javascript - 来自对象数组的 JavaScript 内容

标签 javascript html dom

我是 JavaScript 的新手,我想这样做:我有一个包含对象的数组(一个对象有标题、封面、作者和评级),我想用这些对象填充 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本身提供的函数和对象。

最佳答案

这就是像 Handlebars 这样的模板引擎和类似的东西非常方便:您可以定义一个完全符合您需要的模板,然后让引擎使用对象作为基础来渲染模板。

例如,对于 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 的下一个版本“ES6”将把模板字符串作为语言的一部分。


您在评论中(间接地)说过您不能使用 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"
  })
);

关于javascript - 来自对象数组的 JavaScript 内容,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31368002/

相关文章:

javascript - $http 在 Angular 1.4.8 中使用 Rest Controller

javascript - 扩展 bootstrap-typeahead 以获取对象而不是字符串

javascript - 由于特殊性,使用 jQuery 添加 'active' 类不起作用

javascript - innerText/textContent 与检索每个文本节点

javascript - 使用左右箭头向上滑动内容

javascript - 如何模拟 `instanceof` 测试?

在 Mac OSX 上的 Firefox 中使用 JQuery 的 Javascript 表构造错误

html - 如何在 Bootstrap 中拉伸(stretch)容器以适应整个页面

javascript - 如何在服务器端查看用户认证状态

javascript - Firefox 将注释文本保存在 style 元素内的 textContent 中