Backbone 学习总结
1.Backbone描述
官网描述:(1)Provides client-side app structure
(2)Models to repents data
(3)View to hook up Models to the DOM
(4)Synchonizes data to/from server
Backbone(也称为 Backbone.js)是一个轻量级库,可用于创建 MVC 类应用程序。模型、视图、集合和路由器是 Backbone 框架中的主要组件。在 Backbone 中,模型会存储通过 RESTful JSON 接口从服务器检索到的数据。模型与视图密切关联,负责为特定 UI 组件渲染 HTML 并处理元素上触发的事件,这也是视图本身的一部分。
- 强制依赖于 Underscore.js,Underscore.js 是一个实用型库
- 非强制依赖于 jQuery/Zepto
- 根据模型的变更自动更新应用程序的 HTML,有助于代码维护
- 促进客户端模板使用,避免了在 JavaScript 中嵌入 HTML 代码
模型、视图、集合各司其职,如下图所示:

2.Backbone 之 View
创建基类:
var TodoView = Backbone.View.extend({
el/tagName: ‘<ul></ul>’,
templete:_.templete(‘<h3><%=description%></h3>’),
events:{
“<event> <selector>” : <method>
},
initialize : function() {
this.model.bind("change", this.render, this);
} ,
render: function(){
var attr = this.model.toJSON();
this.$el.html(this.templete(attr));
},
<method>: function(){
//todo
}
});
// el / tagName 可以是任意合法的dom节点,默认是<div></div>
//_.templete是强依赖的underScore.js 的方法,但是在实际应用中我们会选择功能更强大的模板引擎 如 Handlebars.js 来处理模板文件(就是我们写的DOM html)
// events属性给模板文件绑定事件,非常方便
//initialize中将render方法直接绑定在模型的变更事件上,当模型发生更改时,会自动触发 render() 方法,从而节省数行代码。
//render方法中的 this.$el —>topElement(el/tagName)
创建实例:
var todoView = new TodoView({model: todoItem});
todoView.render();
todoView.$el.html(); //实际加入DOM
//可以在view上绑定和解绑定事件
todoView.on('event-name', method);
todoView.off('event-name', method);
//触发绑定的事件
todoView.trigger('event-name');
3.Backbone 之 Model
创建基类:
var TodoItem = Backbone.Model.extend({
defaults:{key:value},
validate: function(){...} //用于验证模型,一般需要重写,在调用 set() 方法时触发
});
创建实例:
var todoItem = new TodoItem({JSON});
todoItem.url = ‘/todo’;
todoItem.fetch(); //触发默认url请求
todoItem.save(); //post URL
//save() 函数将在后台委托给 Backbone.sync,这是负责发出 RESTful 请求的组件,默认使用 jQuery 函数 $.ajax()。首先保存模型对象,使用一个 POST 请求,创建一个标识符 ID,其后,尝试发送对象到服务器,使用一个 PUT 请求。
todoItem.set(key,value);
todoItem.get(‘key’);
todoItem.destroy(); //删除URL
todoItem.toJSON(); //从Model获得JSON数据
todoItem.on(event,method); //绑定事件
todoItem.off(event,method);//解绑定事件
todoItem.trigger(‘event’);//触发绑定事件
event包括:
change,change:<attr>, sync, destroy,
error(model.save / model.validation failed), all(Any triggered)
4.Backbone 之 Collection
Collection 就是Model的集合,提供了很多处理Model的接口。一般的对应关系如下情况:
Model—View
Model—View
Collection — View — Model—View
Model—View
Model—View
基类和实例:
var TodoList = Backbone.Collection.extend({
model : TodoItem,
url: ‘/todo’,
parse: function(data){
//data contains the raw JSON object
console.log(data);
}
});
//在一些情况下,要操作来自服务器的原始数据,可以使用集合的 parse() 方法。
var todoList = new TodoList();
todoList 有一些属性: .length / .add(model) / .at(index) 返回model / .get(1) 返回model / .remove(model) / .fetch() Get URL ’/todo’
//一些常用方法
//添加和移除监听事件
todoList.on(‘event-name’, method);
todoList.off(‘event-name’, method);
todoList.fetch();//调用集合默认URL属性,使用 Ajax GET 请求从服务器取出 JSON 数据
todoList.reset(); // 允许将多个模型设置到一个集合中
todoList.forEach(function(todoItem){});
todoList.map(function(todoItem){});
todoList.filter();
…
5.Bankbone 之 Router
基类和路由实例:
var Router = new Backbone.Router.extend({
routes:{URL (“todo/:id”): Method(‘show’)},
show: function(id){
this.todoList.focusOnTodoItem(id);
},
initialize: function(options){
this.todoList = options.todoList;
},
start: function(){
Backbone.history.start(); //灵魂,开启backbone 路由工作机制
}
});
var mainApp = new Router();
总结下:
Backbone在实际应用都是先建立基类,然后创建实例,写我们的业务。
MVC 模式可以为大型 JavaScript 应用程序提供所需的组织化代码。Backbone 是一个 JavaScript MVC 框架,它属于轻量级框架,且易于学习掌握。模型、视图、集合和路由器从不同的层面划分了应用程序,并负责处理几种特定事件。处理 Ajax 应用程序或者 SPI 应用程序时,Backbone 是比较好的解决方案。
6.AngularJs 和 Backbone的使用对比
Angular:
Angular的特色就是依赖注入,双向绑定(MVVM),加上ui-router路由机制和指令灵活定义很强大,并且还是一个很标准的MVC模式。Angular:有国定的模式,无需自己封装太多代码,创 建模型和控制器比较灵活。mvc=model+controller+view
view:一些含有angular指令的html页面。ng-controller, ng-bind, ng-html...
controller:绑定view的数据,处理业务逻辑和server进行交互,发送rest请求。
model:数据模型,这个是与后台数据定义保持一致。
Backbone:
Backbone 相对Angular,更轻量些。显示模板,创建数据绑定,连接组件,比较自由。主要是CMV = Collection+Model+View。
Collections有随时可枚举函数的丰富API,监听Model事件。
Model一般来绑定键值数据和自定义事件,可以绑定模型验证。
View声明事件处理函数,书写主要的交互逻辑,Restful Json 链接Application,主要来处理DOM。(view和页面DOM是两个概念)
Templete模板引擎,使得页面定义更灵活。当然需要自己手动书写的代码就比较多些。
Controller是自己封装起来处理逻辑的部分,一般初始化view,model,路由的入口处理。
总之可以根据自己的需求,自由选择前端框架,前端底子好,可以用Backbone,一般的话Angular,因为Angular是一个比较完整标准的框架,后台人员更容易介入。
Backbone 学习总结的更多相关文章
- Backbone学习笔记一Backbone中的MVC
原文章地址http://bigdots.github.io/2015/12/01/Backbone学习笔记(一)/#more Backbone.js为复杂WEB应用程序提供模型(models).集合( ...
- Backbone 学习笔记
Backbone 是一款基于模型-视图-控制器 MVC 模式的轻量级javascript 框架 ,可以用来帮助开发人员创建单页Web应用. 借助Backbone 我们可以使用REST的方式来最小化客户 ...
- backbone学习总结(一)
入职第三天,新公司项目用到backbone+underscore+require等框架,前两天把项目的开发环境都配置好啦,项目也能跑起来,现在准备好好学习公司自己的框架以及用到的框架,有点想吐槽,开发 ...
- backbone学习笔记(一)
因为工作的需要,从今天起对backbone的学习过程做下记录. 学习计划: 1.1周看基本知识(2014/1/18-2014/1/25) 2.基本知识总结(2014/1/26) 3.半周按教程写hel ...
- Backbone学习笔记 - View篇
Backbone是一种Web端的MVC框架,这里纪录学习Model,View和Collection的笔记. 1 View initialize构造函数 Backbone.View 与jQuery库紧密 ...
- Backbone学习总结
Backbone中文学习文档:http://www.css88.com/doc/backbone/ 来到公司已经有一段时间了,到现在深深的感觉到自己的能力弱的像只周黑鸭,又干涩又黝黑,充满了麻(手麻脑 ...
- backbone学习总结(二)
今天来看下backbone的路由控制的功能.其实个人感觉backbone,模块就那么几个,熟悉它的框架结构,以及组成,就差不多. 废话不多说,我们来看看还剩下的功能. 关于路由和历史管理 通过 Bac ...
- backbone学习笔记一
backbone是一个MVC单页面框架,针对传统的WEB开发B/S架构的缺点,即通过表现层的浏览器,功能层的WEB服务器,数据层的数据库服务器构架,而操作渲染过程太过复杂.
- Backbone学习笔记
model model的get和set是对model.attributes进行操作,并不是直接对model进行操作 collection collection.set()会触发相应的add,remov ...
随机推荐
- .net core部署到Ubuntu
1.使用vs2017创建Asp.net Core Web应用程序,选择ubuntu中安装的.net core版本,这里选择2.1版本: 2.右键发布该项目,选择文件系统发布: 3.在ubuntu中安装 ...
- centos6升级python
CentOS 6中,默认安装了Python 2.6.而pip,jupyter这样的常用工具是不支持Python 2.6的.为了使用这些工具,就必须将Python 2.6升级到Python 2.7以上的 ...
- web 页面上纯js实现按钮倒计数功能(实时计时器也可以)
需求构思:本功能想实现的是,一个按钮在页面载入就显示提醒续费,,,倒数60秒后,完成提醒功能,可以按另外一个页面跳转到主页. 参考网上的大神,实现如下:Button2倒数,Button3跳转,在页面上 ...
- js计算两个日期相差天数
//两个时间相差天数 兼容firefox chrome var days = function(startDate) { var sdate = new Date(startDate.replace( ...
- Asp .Net Core 2.0 登录授权以及多用户登录
用户登录是一个非常常见的应用场景 .net core 2.0 的登录方式发生了点变化,应该是属于是良性的变化,变得更方便,更容易扩展. 配置 打开项目中的Startup.cs文件,找到Configur ...
- wire [7:0] regAddr; 理解
首先要指出的是wire[7,0]a和wire[8,1]a这样的表达在verilog中是错误的,应该写成wire[7:0]a和wire[8:1]a wire[7:0]a表示定义了一个wire型数据,该数 ...
- nginx——Nginx 防爬虫优化
if ($http_user_agent ~* "qihoobot|Baiduspider|Googlebot|Googlebot-Mobile|Googlebot-Image|Mediap ...
- 剑指Offer 37. 数字在排序数组中出现的次数 (数组)
题目描述 统计一个数字在排序数组中出现的次数. 题目地址 https://www.nowcoder.com/practice/70610bf967994b22bb1c26f9ae901fa2?tpId ...
- 关于测绘软件南方CASS(7.0)成图系统的使用心得
关于测绘软件南方CASS(7.0)成图系统的使用心得 王天池 南方CASS是一款基于CAD平台开发的一套集地形地籍空间数据建库工程工程应用土石算量等功能为一体的绘图软件. 初识这款软件是在大二校园 ...
- 莫烦tensorflow(8)-CNN
import tensorflow as tffrom tensorflow.examples.tutorials.mnist import input_data#number 1 to 10 dat ...