前言

这两天看了下Backbone.js的知识,大概了解了这个框架的一些知识。 写篇博客总结一下。

Backbone.js是一个web端javascript的轻量级MVC框架。为什么说是轻量级呢?因为它基于underscore(基于jQuery)和jQuery这2个框架,熟悉jQuery的小伙伴们可以快速入门Backbone.js。

为何使用Backbone

使用Backbone.js可以让你像写Java代码一样对js代码进行组织,比如定义类,类的属性、方法,这点非常重要。

比如传统的js开发是这样的:

<input type="button" value="save" onclick="save()"/>
<input type="button" value="add" onclick="add()"/> ... // js代码
function save() {
...
}
function add() {
...
}
</script>

页面内容一多,js代码会分布在页面的各个角落,维护、开发都很麻烦。

使用Backbone处理:

var AppView = Backbone.View.extend({
el: "body", // 事件
events: {
'click input[type=button][value=add]': 'add',
'click input[type=button][value=save]': 'save'
}, add: function(event) {
...
}, save: function(event) {
...
} }); var appView = new AppView;

使用Backbone之后,所有js的代码都会在同一个地方,也就是对js代码进行了组织,我只需要管理这段js代码即可,前面button里的onclick事件就不需要单独写了。

Backbone中的几个重要概念

Backbone中有4个重要的概念,分别是Model,Collection,View,Router。

Model

Model是Javascript应用程序的核心,包括基础的数据以及围绕着这些数据的逻辑:数据转换、数据验证、访问控制。自定义的Model可以继承Backbone.Model。1个Person实体:

var Person = Backbone.Model.extend({
initialize: function() {
// 构造实例的时候会调用这里
},
//默认属性
defaults: {
name: 'unknow',
age: 0
},
validate: function(attributes) {
if(!attributes.age || attributes.age < 0) {
return "年龄小于0,出问题了";
}
},
customMethod: function() {
console.log("自定义方法");
}
}); // 实例化1个Person对象
var person = new Person;
console.log(person.get('name')); // unknow
console.log(person.get('age')); // 0 person.set('name', 'format');
console.log(person.get('name')); // format person.set({name: 'james', age: 33});
console.log(person.get('age') + ', ' + person.get('age')); // james, 33 person.customMethod(); // 自定义方法 //设置其他属性
person.set({birth: '1977-12-15'});
console.log(person.get('birth')); // 1977-12-15 console.log(person.attributes); //{name: "james", age: 33, birth: "1977-12-15"} if(!person.set({age: '-1'})) { //set属性默认不验证,这边set age 0,可以设置进去
console.log('设置age属性出错------11'); //这里不会打印
} if(!person.set({age: '-1'}, {validate: true})) { //set 的时候加上validate: true, 让其验证,这里验证出错返回false
console.log('设置age属性出错------22'); //这里会打印
}

更加详细的资料请参考Model

Collection

Collection, 集合, 也就是多个Model,很好理解。

可以绑定'change', 'add', 'remove'事件到集合上以监听集合的数据状态。

// 这里的代码依赖之前的Person这个Model
var Family = Backbone.Collection.extend({
model: Person,
initialize: function() {
//构造集合会调用这里
}
}); var father = new Person({name: 'father', age: 42});
var mother = new Person({name: 'mother', age: 40}); var family = new Family([father, mother]); family.bind('change', function(person) {
console.log('family集合有数据改变了: ' + person.get('age'));
}); family.bind('add', function(person) {
console.log('family集合有数据进来了: ' + person.get('name'));
}); family.bind('remove', function(person) {
console.log('family集合有数据被删掉了: ' + person.get('name'));
}); // 触发add事件
family.add(new Person({name: 'son', age: 0}));
// 触发remove事件
family.remove(father);
// 触发change事件
mother.set('age', 41); // 查询
console.log(family.where({name: 'son'})); [son] // 触发add事件
family.add(father); // 比较器,排序使用
family.comparator = 'age';
family.sort(); //根据age排序,并从对象里拿出name属性
console.log(family.pluck('name')); // ["son", "mother", "father"]

更加详细的资料请参考Collection

View

Backbone的View是用来显示你的model中的数据到页面的,同时它也可用来监听DOM上的事件然后做出响应。

html:

<ul id="persons">

</ul>
<input type="button" value="add"/>

javascript:

$(document).ready(function() {

    var AppView = Backbone.View.extend({
// 注意这里的el是body,不然的话下面的事件绑定不了。下面事件的element是基于el进行查找的
el: 'body', events: {
'click input[type=button][value=add]': 'add',
'click #persons li': 'remove'
}, add: function(event) {
var name = window.prompt("请输入名字");
this.$('#persons').append('<li>' + name + '</li>');
}, remove: function(event) {
$(event.target).remove();
} }); var appView = new AppView; });

更加详细的资料请参考View

Router

Router既控制器,用来监控一些#(锚)地址的访问情况。

var AppRouter = Backbone.Router.extend({

    routes: {
//* 代表全部, : 代表1个
"all/*action": "actionRoute", // all/*action 会截获all/后面全部的地址
"posts/:id": "posts", // :id 会截获
"trigger": "trigger"
}, actionRoute: function(actions) {
console.log("all/*action生效了,具体的地址: " + actions);
}, posts: function(id) {
console.log("posts/:id生效了,id: " + id);
}, trigger: function() {
//手动触发其他route, 参数trigger表示触发事件,如果为false,则只是url变化,并不会触发事件,replace表示url替换,而不是前进到这个url,意味着启用该参数,浏览器的history不会记录这个变动。
appRouter.navigate("/posts/" + 404, {trigger: true, replace: true});
} }); var appRouter = new AppRouter; // 使用Router必须要有以下这个代码
Backbone.history.start();

更加详细的资料请参考Router

总结

总结了一下Backbone中4大核心概念的知识,接下来准备写一个使用Backbone的小项目。

吐槽一下,这篇文章用markdown写的,cnblog中的markdown里使用了highlightjs对代码进行了着色,但是楼主以前在博客园里就是用hightlightjs的,现在两者冲突了, 蛋疼。

还有h2标签生成的时候id属性有问题。 所以就先不贴菜单了。

参考资料:

https://github.com/the5fire/backbonejs-learning-note

http://www.cnblogs.com/yexiaochai/archive/2013/07/27/3219402.html

Backbone小记录的更多相关文章

  1. Java 打印金字塔 or 打印带数字的金字塔 (Java 学习中的小记录)

    Java 打印金字塔 or 打印带数字的金字塔 (Java 学习中的小记录) 作者:王可利(Star·星星) 效果图: 代码如下: class Star8 { public static void m ...

  2. Java 需要记得、了解的关键词 (Java 学习中的小记录)

    Java 需要记得.了解的关键词 (Java 学习中的小记录)     作者:王可利(Star·星星) 总结:本次随笔,仅且拿来平时翻阅记忆用

  3. 关于HTML中,绝对定位,相对定位的理解...(学习HTML过程中的小记录)

    关于HTML中,绝对定位,相对定位的理解...(学习HTML过程中的小记录)   作者:王可利(Star·星星) HTML中 相对定位:position:relative; 绝对定位:position ...

  4. 利用JQ实现的,高仿 彩虹岛官网导航栏(学习HTML过程中的小记录)

    利用JQ实现的,高仿 彩虹岛官网导航栏(学习HTML过程中的小记录)   作者:王可利(Star·星星) 总结: 今天学习的jQ类库的使用,代码重复的比较多需要完善.严格区分大小写,在 $(" ...

  5. html/css 盒子布局 Margin 、Padding 、border 以及 清除浮动的知识 (学习HTML过程中的小记录)

    html/css  盒子布局 Margin .Padding .border 以及 清除浮动的知识 (学习HTML过程中的小记录) 作者:王可利(Star·星星) width     是"宽 ...

  6. NDK开发小记录 C++读取java层对象内容

    这是自己NDK开发得小记录,关于C++层读取java层传来的对象内容. 很简单的一个例子, 1.首先在java层定义了一个类NumList: public class NumList { public ...

  7. centos 6.X minimal 系列最小化安装完成后,安装mono和jexus过程小记录

    在使用虚拟机安装minimal版centos运行mono+jexus的时候,遇到了一些坑,记录一下,比如虚拟机访问不了网络,没wget命令没开放80端口,等等小问题,其他网上教程已经有mono+jex ...

  8. HorizontalScrollView做页卡的一个小记录

    用HorizontalScrollView做页卡,实现一个如下图的效果:

  9. easy-ui JOB 及 小记录

    $:获取  $.ajax({             type: "POST" ,             url: "" ,             cont ...

随机推荐

  1. .net串口通信

    背景: 前一段时间需要写一个向蓝牙模块发消息的功能. 对蓝牙的机制不太了解,所以一直在查资料, 但始终没找到我需要的东西,还误以为需要配套的一套开发模板和开发包, 偶然间发现只需要简单的串口通信,并且 ...

  2. 传递给后台的Json数据解析

    后台代码如下: public void ProcessRequest(HttpContext context) { context.Response.ContentType = "appli ...

  3. jquery实践案例--验证电子邮箱

    <input type="email" name="email" id="email" value="" onpa ...

  4. 版本控制工具VSS使用介绍

    什么是版本控制? 1.怎样对研发项目进行整体管理 2.项目开发小组的成员之间如何以一种有效的机制进行协调 3.如何进行对小组成员各自承担的子项目的统一管理 4.如何对研发小组各成员所作的修改进行统一汇 ...

  5. python set集合简单使用

    Python 提供了强大的集合操作方法,我们可以完成数学中集合的并集.交集.差集等操作,如下: >>> a = {1,2,3} >>> b = {3,4,5} &g ...

  6. NOIP2013普及组 -SilverN

    T1  计数问题 题目描述 试计算在区间 1 到 n 的所有整数中,数字 x(0 ≤ x ≤ 9)共出现了多少次?例如,在 1 到 11 中,即在 1.2.3.4.5.6.7.8.9.10.11 中, ...

  7. uva 10562 undraw the trees(烂题) ——yhx

    aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAABB4AAAM9CAYAAAA7ObAlAAAgAElEQVR4nOyd25GsupKGywVswAV8wA ...

  8. iOS开发之——制作framework静态库教程

    环境: 硬件:macbook air 系统:OSX EI Capitan 版本:10.11.3 xcode : Version 7.2.1 (7C1002) 最近在做ios的静态库(据说framewo ...

  9. Could not open INSTALL.LOG file

    今天卸载MailEnable时弹出这个提示,用360这样的工具卸载问题依旧,折腾了大半天没解决 UNWISE Could not open INSTALL.LOG file 本人有强迫症,虽然这个软件 ...

  10. Jetson TK1刷机+配置Mini PCI-e无线网卡

    最近买了台4K电视,觉得可以当显示器用,但没主机,不知怎的想到了Jetson TK1,于是一冲动买了.因为没网线,而Jetson TK1没有无线网卡,所以也折腾了一番,记录一下,给万一也有像我一样没有 ...