我刚刚开始使用Backbone,并完成了一个教程。我跟着进去并输入了代码,当我走到尽头时(我在整个测试中得到underscore cannot call 'replace' of null
就像我说的那样 - 刚刚开始,所以任何关于不仅如何解决的信息,以及它为什么会破坏都会很棒!
HTML
<!-- ## CART CONTAINER ## -->
<div id="yourcart"></div>
<!-- ## SCRIPTS ## -->
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.7.2/jquery.min.js"></script>
<script src="js/underscore.js"></script>
<script src="js/backbone.js"></script>
<script src="js/cart.js"></script>
<!-- ## TEMPLATE ## -->
<script id="itemTemplate" type="text/template">
<img src="<%= photo %>" alt="<%= title %>">
<div>
<h2><%= title %></h2>
<h4>£<%= price %></h4>
</div>
</script>
JAVASCRIPT
// MODEL
var Item = Backbone.Model.extend({
defaults: {
price: 35,
photo: "http://www.placedog.com/100/100"
}
});
// COLLECTION
var Cart = Backbone.Collection.extend({
model: Item
});
var items = [
{ title: "Macbook Air", price: 799 },
{ title: "Macbook Pro", price: 999 },
{ title: "The New iPad", price: 399 },
{ title: "Magic Mouse", price: 50 },
{ title: "Cinema Display", price: 799 }
];
var cartCollection = new Cart(items);
// ITEM VIEW
var ItemView = Backbone.View.extend({
tagName: "div",
className: "item-wrap",
template: $('#itemTemplate').html(),
render: function() {
var templ = _.template(this.template);
this.$el.html(templ(this.model.toJSON()));
return this;
}
});
// COLLECTION VIEW
var CartCollectionView = Backbone.View.extend({
el: $('#yourcart'),
initialize: function() {
this.collection = cartCollection;
this.render();
},
render: function() {
this.collection.each(function(item) {
this.renderItem(item);
}, this);
},
renderItem: function(item) {
var itemView = new ItemView({ model: item });
this.$el.append(itemView.render().el);
}
});
$(function() {
var cart = new CartCollectionView();
});
答案 0 :(得分:1)
没有看到有关HTML
/ Scripts
位置的任何信息,但是一旦我将template
代码移到其他脚本之上就完美了。