演示.js
var CommentsCollection = Backbone.Collection.extend({
url : "http://0.0.0.0:8080/"
});
var CommentsListView = Backbone.View.extend({
el: '.page',
render : function(){
var that = this;
var commentsCollection = new CommentsCollection();
commentsCollection.fetch({
success: () => {
var models = commentsCollection.models;
// _.each(models, function(models){
// console.log(models.get('firstname'));
// });
var template = _.template($('#reddit-comments-template').html());
that.$el.html(template(models));
}
})
}
});
var PageRouter = Backbone.Router.extend({
routes: {
'' : 'home'
}
});
Backbone.history.start();
索引.html
<html>
<head>
<title> </title>
</head>
<body>
<div class="container">
<h1>Top posts</h1>
<hr />
<div class="page"></div>
</div>
<script type="text/template" id="reddit-comments-template">
<table class = "comments table">
<thead>
<tr>
<th>Row</th>
<th>Commments</th>
</tr>
</thead>
<tbody>
<tr>
<% _.each(models, function(models){ %>
<tr>
<td><%= models.get('firstname') %></td>
<td><%= models.get('lastname') %></td>
<td><%= models.get('id') %></td>
</tr>
<% }); %>
</tr>
</tbody>
</table>
</script>
<script type="text/javascript" src="jquery-3.2.1.min.js"></script>
<script type="text/javascript" src="underscore-min.js"></script>
<script type="text/javascript" src="backbone-min.js"></script>
<script type="text/javascript" src="demo.js"></script>
</body>
</html>
实际上,如果您看到,我尝试了从API获取一些数据,并根据数据中的更改更新视图,集合从API获取数据,然后我获取集合的模型,以循环来自模型的数据,模型中的变量会打印在我添加到js脚本的日志中的注解中,正如您所看到的,但我猜值不会传递到html文件,导致该错误。请告诉我如何更正它。
2条答案
按热度按时间kkbh8khc1#
您可以将集合转换为json,并将其传递给模板和访问模型,这样您就可以使用_.each迭代模型,并在模板中呈现它们的属性。
模板:
nkhmeac62#
在将集合或模型发送到模板之前,首先用
toJSON()
方法将其序列化,该方法在Backbone的模型和集合上都可用。当我们在集合上使用toJSON
时,它返回一个包含每个模型的属性哈希的数组。PS:我已经在成功回调中添加了默认参数。