Backbone.js入门教程第二版笔记(1)
1、模块 集合 视图 和事件的一个综合例子
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Document</title>
<script src="jquery-1.9.1.js"></script>
<script src="underscore.js"></script>
<script src="backbone.js"></script> </head>
<body>
<button id="check">新手报到</button>
<ul id="world-list">
</ul>
<script>
(function ($) { var World=Backbone.Model.extend({
name:null //为什么要创建一个空的name
}); var Worlds=Backbone.Collection.extend({
initialize:function(models,options){
this.on("add", options.view.addOneWorld);//初始化绑定add方法
}
}); var AppView=Backbone.View.extend({
el:$('body'),//指定关联的元素
initialize:function(){//初始化方法
this.worlds=new Worlds(null,{view:this})//实例化一个集合,并且建一个属性view用来保存视图
},
events:{
'click #check':"checkIn"//绑定#check的click事件
},
checkIn:function(){
var world_name=prompt("请问,您是哪星人?");
world_name||(world_name = '未知'); var world=new World({name:world_name});//实例化一个模块,并设置name的值
this.worlds.add(world);//将模块添加到集合
},
addOneWorld:function(model){
$("#world-list").append("<li>这里是来自 <b>" + model.get('name') + "</b> 星球的问候</li>");
}
});
var appview = new AppView;//实例化AppView })(jQuery);
</script>
</body>
</html>
2、为对象添加验证规则与错误提示
var User=Backbone.Model.extend({
defaults:{
name:'susan',
age:18
},
url:"1.html",//需要设置url,因为save会调用sync方法把数据提交到服务器
initialize:function(){
this.on("invalid",function(model,error){//初始化时绑定验证未通过时的事件处理函数
console.log(error);
});
},
validate:function(attributes){//重写验证方法 不返回或返回falsy值(假值)时不会触发invalid?
if(attributes.name==""){
return "name 不能为空!";
}
}
});
var user=new User();
user.set("name","");
user.save();//当save时会触发validate方法
3 根目录 urlRoot
var Book = Backbone.Model.extend({
urlRoot:'/backbone_test',
defaults:{"name":"Su","age":14}
});
var solaris = new Book({id: "data.php"});
console.log(solaris.url());///backbone_test/data.php
solaris.save();
4 使用fetch从服务端获取数据(collection中并没有urlRoot属性)
var Book = Backbone.Model.extend({//创建一个Model
defaults : {
title:'default'
}
});
var BookShelf = Backbone.Collection.extend({//创建一个集合
model : Book,
url:'user.json'
});
var book1 = new Book({title : 'book1'});//实例化二个model
var book2 = new Book({title : 'book2'});
var bookShelf = new BookShelf([book1, book2]); //实例化集合,并将这2个model添加到集合中,也可以使用collection.add(model)添加。
// bookShelf.url = 'user.json'; //或者在这里添加url
bookShelf.fetch({
success:function(collection, response, options){
collection.each(function(book){
console.log(book.get('title'));//default
});
},error:function(collection, response, options){
console.log('error');
}
});
6 create方法 发送数据到服务端
var NewBooks = Backbone.Collection.extend({
model: Book,
url: '/books/'
});
var books = new NewBooks;
var onebook = books.create({
title: "I'm coming",
});
create方法会在内部调用save方法,而save方法前面提过它会调用sync把数据提交到服务器。看源码也可以知道,create方法最后返回了创建的model实例

Backbone.js入门教程第二版笔记(1)的更多相关文章
- Backbone.js入门教程第二版笔记(3)
视图渲染 <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <titl ...
- Backbone.js入门教程第二版笔记(2)
关于手动触发router,之前看到的例子都是通过在url后面加上#xxx或者点击一个a链接方法来触发, 还有一种情况是通过触发一种规则,来触发另一种规则(表述无能),比如这个例子中,我在url后面加上 ...
- Backbone.js入门教程
原文: Getting Started with Backbone.js 不像其它的Web开发语言,过去Javascript很少可用的架构.令人感到高兴的是,最近几年这种情况得到非常大的改善. 今天我 ...
- D3.js 入门教程
最近需要用到d3, 记录下d3的教程 网上搜了几个关于d3的教程 D3.js 入门教程 http://wiki.jikexueyuan.com/project/d3wiki/author.h ...
- 【特别推荐】Node.js 入门教程和学习资源汇总
这篇文章与大家分享一批很有用的 Node.js 入门教程和学习资源.Node 是一个服务器端的 JavaScript 解释器,它将改变服务器应该如何工作的概念.它的目标是帮助程序员构建高度可伸缩的应用 ...
- python核心编程第二版笔记
python核心编程第二版笔记由网友提供:open168 python核心编程--笔记(很详细,建议收藏) 解释器options:1.1 –d 提供调试输出1.2 –O 生成优化的字节码(生成 ...
- Node.js 入门教程和学习资源汇总
这篇文章与大家分享一批很有用的 Node.js 入门教程和学习资源.Node 是一个服务器端的 JavaScript 解释器,它将改变服务器应该如何工作的概念.它的目标是帮助程序员构建高度可伸缩的应用 ...
- 【CC2530入门教程-增强版】基础技能综合实训案例(基础版)-上位机源码
[CC2530入门教程-增强版]基础技能综合实训案例(基础版)-上位机源码 广东职业技术学院 欧浩源 一.需求分析 按照指定参数打开串口,与测控终端建立数据传输通道,并根据应用要求实现程序逻辑,具体 ...
- Vue.js 入门教程
Vue.js 入门教程:https://cn.vuejs.org/v2/guide/index.html
随机推荐
- 6.游戏特别离不开脚本(4)-应该避免将集合框架对象传给JS
java map 传给 javascript 不是自动关联的,最好别传啊,遍历起来也麻烦(尽量避开集合框架吧),用数组或者自建一个对象.这里虽然有种方法: // build a Map Map< ...
- REST RPC HTTP vs 高性能二进制协议 序列化和通信协议
edisonchou https://mp.weixin.qq.com/s/-XZXqXawR-NxJMPCeiNsmg .NET Core微服务之服务间的调用方式(REST and RPC) Edi ...
- SyntaxError:Strict mode does not allow function declaration in a lexically nested statement.
问题描述 使用react-native init创建了一个新项目,在package.json中使用的react-native的版本如下: "dependencies": { & ...
- 恢复MySQL数据库删除的数据
在日常运维工作中,对于数据库的备份是至关重要的!数据库对于网站的重要性使得我们对 MySQL 数据库的管理不容有失!然而是人总难免会犯错误,说不定哪天大脑短路了,误操作把数据库给删除了,怎么办? 下面 ...
- local_irq_disable
local_irq_disable 仅仅是 设置 当前CPU 的中断屏蔽位 disable_irq 是禁用 全部cpu 中断(只是当前irq) 如果你要禁止所有的中断该怎么办? 在2.6内核中,可以通 ...
- CentOS 7 安装jdk9
1.下载jdk9 http://download.oracle.com/otn-pub/java/jdk/9.0.4+11/c2514751926b4512b076cc82f959763f/jdk-9 ...
- 如何去掉idea里mybatis的.xml文件 sql 语句背景色
点击有背景的地方 Alt+Enter选择 un-inject Language/refence 即可去掉
- SpringBoot快速HelloWorld入门
1.新建maven项目 2.pom.xml 里添加SpringBoot所依赖的jar包 <parent> <groupId>org.springframework.boot&l ...
- 给jenkins设置管理员
1.点击jenkins web 页的Manage Jenkins,然后点击 Configre Global Security,进行安全配置: 2.启用安全设置,使用Jenkins 自带数据库,只允许登 ...
- c#操作rabbitmq
今天将会介绍如果使用rabbitmq进行简单的消息入队,出队操作,因为本文演示的环境要用到上文中配置的环境,所以要运行本文sample,请先按上一篇中完成相应环境配置. 首先,我们下载 ...