我正在尝试从我的骨干视图中呈现此模板,但它不起作用?任何人都知道我在做错了谢谢!我将包含我的jade文件用于视图和main.js文件用于骨干js脚本。
玉文件
extends layout
block content
div.centerContent
script(type="text/javascript", src="/js/main.js")
h4 User goes here with equal before it no space
div#user
p #{firstName} #{lastName}
p #{email}
p #{phone}
p #{birthday}
button.edit Edit
script(id="userTemplate", type ="text/template")
p #{firstName} #{lastName}
p #{email}
p #{phone}
p #{birthday}
button.edit Edit
script(id="userEditTemplate", type ="text/template")
div
form(action="#")
input(type="text", class="firstName", value=#{firstName}) input(type="text", class="lastName", value=#{lastName})
input(type="email", class="email", value=#{email})
input(type="number", class="phone", value=#{phone})
input(type="date", class="birthday", value=#{birthday})
button.save Save
button.cancel Cancel
hr
Main.Js文件
(function () {
window.App = {
Models: {},
Collections: {},
Views: {},
Templates: {},
Router: {}
};
// MODEL
App.Models.User = Backbone.Model.extend({
defaults: {
firstName: 'first',
lastName: 'last',
email: 'Email',
phone: '222',
birthday: 'date'
},
validate: function (attrs) {
if (!attrs.firstName) {
return 'You must enter a real first name.';
}
if (!attrs.lastName) {
return 'You must enter a real last name.';
}
if (attrs.email.length < 5) {
return 'You must enter a real email.';
}
if (attrs.phone.length < 10 && attrs.phone === int) {
return 'You must enter a real phone number, if you did please remove the dash and spaces.';
}
if (attrs.city.length < 2) {
return 'You must enter a real city.';
}
},
initialize: function() {
user.on('invalid', function (model, invalid) {
console.log(invalid);
});
}
});
//VIEW
App.Views.User = Backbone.View.extend({
model: App.Models.User,
//tagName: 'div',
//id: 'user',
//className: 'userProfile',
template: _.template($("#userTemplate").html());
editTemplate: _.template($("#userEditTemplate").html());
initialize: function (){
}
render: function() {
this.$el.html(this.template(this.model.toJSON()));
return this;
},
events: {
'click button.edit': 'editProfile',
// 'click button.save': 'saveEdits',
'click button.cancel': 'cancelEdits'
},
editProfile: function () {
this.$el.html(this.editTemplate(this.model.toJSON()));
},
cancelEdits: function() {
this.render();
}
});
//start history service
Backbone.history.start();
var user = new App.Views.User({el: 'div #user'});
user.render();
})();
答案 0 :(得分:1)
我发现您没有为主干视图分配模型。
所以你可以试试这个:
var MyModel = Backbone.Model.extend({
defaults: {
name: 'first',
lastName: 'last',
email: 'Email',
phone: '222',
birthday: 'date'
}
});
var MyView = Backbone.View.extend({
el: "#user",
model: MyModel,
template: _.template($("#test-template").html()),
render: function(){
this.$el.html(this.template(this.model.toJSON()));
return this;
}
});
var myView = new MyView({model:new MyModel()});
myView.render();
测试模板是:
<script id="test-template" type="text/template">
<div><%=name%></div>
</script>
HTML:
<body>
<div id="user">
</div>
</body>
您可以在Backbone视图声明中定义骨干视图的el属性。并记住在启动模型时为其分配视图。
[编辑]
JADE:
script(id="userTemplate", type ="text/template")
p #{firstName} #{lastName}
p #{email}
p #{phone}
p #{birthday}
button.edit Edit
修改模板生成方法:
<script src="https://raw.github.com/weepy/jade-browser/master/jade.js"></script>
<script src="https://raw.github.com/weepy/jade-browser/master/jade-shim.js"></script>
template: jade.compile($("#userTemplate").text());
希望这对你有所帮助。