主干视图不渲染我的模板
Backbone View doesnt render my Template
我看到了一篇关于Backbone中简单视图的小文章。但我尝试加载一个模板在我自己的方式。不工作:(
我复制并粘贴代码到我的文件,但什么都没有发生。下面是我的代码:
<!DOCTYPE html>
<head>
<meta charset="utf-8">
<script type="text/javascript" src="js/vendor/jquery-1.7.1.js"></script>
<script src="js/vendor/underscore.js"></script>
<script src="js/vendor/backbone.js"></script>
</head>
<body>
<div id="search_container"></div>
<script type="text/javascript">
;(function(){
SearchView = Backbone.View.extend({
initialize: function(){
_.bindAll(this, 'render');
},
render: function(){
var template = _.template( $("#search_template").html(), {} );
$(this.el).html(this.template);
this.el.html( template );
}
});
var search_view = new SearchView({ el: $("#search_container") });
})(jQuery);
</script>
<script type="text/template" id="search_template">
<label>Search</label>
<input type="text" id="search_input" />
<input type="button" id="search_button" value="Search" />
</script>
</body>
</html>
包含的所有脚本都是最新版本。我的失败是什么?
感谢所有想帮助我的人:)
yaaan
这是您的代码的工作示例。我把它清理了一下。
<!DOCTYPE html>
<head>
<meta charset="utf-8">
<script type='text/javascript' src='https://ajax.googleapis.com/ajax/libs/jquery/1.7.1/jquery.min.js'></script>
<script type='text/javascript' src='http://ajax.cdnjs.com/ajax/libs/underscore.js/1.1.4/underscore-min.js'></script>
<script type='text/javascript' src='http://cdnjs.cloudflare.com/ajax/libs/backbone.js/0.5.3/backbone-min.js'></script>
<script type="text/javascript">
$(function(){
SearchView = Backbone.View.extend({
initialize: function(){
_.bindAll(this, 'render');
},
render: function(){
$(this.el).html($("#search_template").html());
}
});
var search_view = new SearchView({ el: $("#search_container") });
search_view.render();
});
</script>
<script type="text/template" id="search_template">
<label>Search</label>
<input type="text" id="search_input" />
<input type="button" id="search_button" value="Search" />
</script>
</head>
<body>
<div id="search_container"></div>
</body>
</html>
对_.template()的调用抛出了一个错误,因为没有将模型传递给它,所以我将该方法调用取出。
就像@nikoshr指出的,一旦SearchView被实例化,你就需要调用render()方法。
我还对代码做了一些小的调整,您可以查看一下。
相关文章:
- 将日期时间作为 JSON 发送将无法在我的视图中正确显示
- 为什么不't我的变量在我的控制器中填充后在我的视图中呈现
- 为什么我的视图没有显示在角度ui视图中
- 为什么我无法在我的视图中看到这个变量
- 为什么我的视图模型不起作用
- 如何在我的视图中打印JavaScript代码
- Knockout JS将我的视图模型创建更改为使用映射pulgin
- 如何使用JS函数在我的视图中显示ViewBag的值
- KnockoutJS 绑定在我的视图模型实际创建之前应用
- 我的视图模型不会根据 JSON 结果淘汰来增加数字
- 用AngularJS清理我的视图
- 为什么我的视图在骨干中的数组长度不正确
- Knockoutjs:如何将单个项目从可观察数组传递到我的视图模型中
- Ajax响应并没有改变我的视图模型
- 将参数从我的视图(页面)传递到我的js文件
- 无法使用逻辑从主干路由器路由到我的视图
- 在我的视图页面中实现两个select
- 通过添加“更改”方法,我的视图不再绑定到它
- 使用AngularJS在我的视图中的另一个json中渲染json
- json对象直接从我的视图HTML