认识 Backbone(二) : 什么是 View

Backbone 中的 View 用来反映你 appModel 的模样。它们会监听事件并作出相应的反应。
接下来的教程我不会告诉你如何把 ModelCollection 绑定到 View 上,而是主要讨论 View 是如何使用 javascript 模板库的,尤其是 Underscore.js's _.template
这里我们使用 jQuery 来操作 DOM 元素,当然你也可以使用其他的库,例如 MooTools 或者 Sizzle,但是 Backbone 的官方文档推荐我们使用 jQuery
接下来,我们以搜索框为例来新建一个 View

SearchView = Backbone.View.extend({
    initialize: function(){
        alert("Welcome to Backbone!");
    }
});
var search_view = new SearchView();

在《认识 Backbone(一) : 什么是 Model》一文我已经提到,无论是 ModelView 还是 Collection,当被实例化时,initialize() 方法都会被自动触发。

el 属性

el 属性指的是已经在浏览器中创建好的 DOM 对象,每个 View 都有一个 el 属性,如果它未被定义,Backbone 将会自己创建一个空的 div 元素作为 el 属性。
下面让我们来为 View 创建一个 el 属性,并设为 #search_containe

此时,Viewel 属性指的是 idsearch_containerdiv 元素。我们此时变绑定了这个 div 元素,那么任何我们希望触发的事件都必须在这个 div 元素中。

加载模板

Backbone 是强依赖于 Underscore.js 的,所以我们可以使用 Underscore.js 中的小型模板。
现在,让我们添加一个 render() 方法,并且在 initialize() 中调用它,这样当 View 初始化时便会自动触发 render() 方法。
这个 render() 方法将会通过 jQuery 把模板加载到 Viewel 属性中去。



添加监听事件

我们使用 Viewevents 属性添加监听事件,记住监听事件只能添加到 el 属性的子元素上。现在,我们来给子元素 button 添加一个监听事件。



向模板中传递参数

模板可以通过 <%= %> 的形式使用从 View 中传来的参数。



参考

http://backbonetutorials.com/what-is-a-view/
http://documentcloud.github.io/underscore/

http://jsfiddle.net/tBS4X/1/

你可能感兴趣的:(javascript,backbone)