事件绑定  on()方法

调用格式:object.on(event, callback, [context])
"change" — 当attributes变化时
"change:[attribute]" — 当attributes的一个特定属性变化时
(当同时监听了这2个事件时,触发顺序是先"change:[attribute]"事件,再"change" 事件。)

var User=Backbone.Model.extend({
defaults:{
name:'susan',
age:18},
initialize:function(){
this.on('change',function(){
console.log(1);
})
}
});
var user=new User();
user.set('name','jack');
//
user.set('name','lily');
//
var User=Backbone.Model.extend({
defaults:{
name:'susan',
age:18},
initialize:function(){
this.on('change:name',function(model){
console.log(model.cid);
})
}
});
var user=new User();
user.set('name','lucy');
//c1
var User=Backbone.Model.extend({
defaults:{
name:'susan',
age:18},
initialize:function(){
this.on('change:name',this.show);
},
show:function(){
console.log('show');
}
});
var user=new User();
user.set('name','lucy');
//show

注:在使用on绑定change和change:attr事件时,可以通过其回调函数的参数model获取属性修改之前的值:
model.previous("attrName");//获取单个属性
model.previousAttributes();//获取所有属性

绑定多个事件的两种方式

一、事件之间用空格分隔,如

model.on("eventName1 eventName2",function(){});//1

model.on("eventName:attr1 eventName:attr2",function(){});//2
在测试时,遇到一个觉得困扰的问题:

    var User=Backbone.Model.extend({
name:'susan',
age:18
}); var user=new User(); user.on('change:name change:age',function(model,value){
console.log("changed");
}); user.set({
name:'lily',
age:19
});

我以为只调用了一次set,控制台就只会输出一次“changed”,但事实上它输出了两次:

    var User=Backbone.Model.extend({
name:'susan',
age:18
}); var user=new User(); user.on('change:name change:age',function(model,value){
console.log("changed")
if(model.get('name')!==model.previous('name')||model.get('age')!==model.previous('age')){
console.log(model.get('name'),model.get('age'),value);
} }); user.set({
name:'lily',
age:19
}); //lily 19 lily
//lily 19 19

查看backbone的set方法发现:

for in 遍历把每一项属性名push到changeS数组中,比如在这个例子中,for in之后changes为['name','age']
接着for循环数组changes,触发change:事件,这就是为什么 user.set({name:'lily',age:19})控制台会输出两次的原因。

第二种:先定义一个对象,在对象中以键值对的方式添加事件名称和相应的函数:
var eventObj={
   eventName1:function1,
   eventName2:function2

}

    var User=Backbone.Model.extend({
name:'susan',
age:18
});
var user=new User(); var name_change=function(model,value){ };
    var age_change=function(model,value){

    };
var ev={
"change:name":name_change,
"change:age":age_change
}
user.on(ev); user.set({
name:'lily',
age:19
});

关于这两种方法,第一种需要考虑事件执行顺序和重复执行的可能性,更适合多个执行同一个函数的情景,而第二种适合事件和函数一一对应的情景。

once方法 只执行一次的绑定

调用格式:object.once(event, callback, [context])

    var User=Backbone.Model.extend({
name:'susan',
age:18
});
var user=new User();
var num=0;
user.once("change",function(){
num++;
console.log("changed+"+num);
}) user.set({name:'lily',age:19});
user.set({name:'lily',age:19}); //changed+1

trigger方法 手动触发

调用格式:object.trigger(event, [*args])

    var User=Backbone.Model.extend({
name:'susan',
age:
});
var user=new User();
var num=;
user.once("change",function(){
console.log("changed");
}) user.trigger("change");

off方法 移除事件

调用格式:object.off([event], [callback], [context])

用于移除对象上绑定的一个、多个或者全部事件。移除多个事件时,事件之间用空格分隔,trigger方法也可以用这种方式手动触发多个事件

    var User=Backbone.Model.extend({
name:'susan',
age:18
});
var user=new User();
var num=0;
user.on("change_name change_age",function(){
console.log("changed+"+(++num));
}) user.trigger("change_name change_age");
user.off("change_name change_age");
user.trigger("change_name change_age");

移除绑定事件执行的回调:

    var User=Backbone.Model.extend({
name:'susan',
age:18
});
var user=new User();
var num=0;
var fn=function(){
console.log("changed+"+(++num));
}; user.on("change_name change_age",fn); user.trigger("change_name change_age");
user.off(null,fn);
user.trigger("change_name change_age"); //changed+1
//changed+2
var User=Backbone.Model.extend({
name:'susan',
age:18
});
var user=new User();
var num1=0,num2=0;
var fn1=function(){
console.log("changed+"+(++num1));
};
var fn2=function(){
console.log("changed2+"+(++num2));
};
user.on("change_name change_age",fn1);
user.on("change_name change_age",fn2); user.trigger("change_name change_age");
user.off(null,fn1);
user.trigger("change_name change_age"); // changed+1
// changed2+1
// changed+2
// changed2+2
// changed2+3
// changed2+4

如果要移除所有的事件,不带参数,obj.off()即可。

listenTo方法

view.listenTo(model, 'change', view.render);

第一个参数是模块,第二个参数是事件类型,第三个参数是事件回调。
on与listenTo的区别是:on方法是监听对象中某一个事件的触发,如果触发了事件,就执行回调。而listenTo是一个对象A监听另一个对象B的事件,如果B的事件被触发了,则A要执行自己的回调。

view.listenTo(model,'change',view.render) 等价于  model.on('change',view.render,view)

var User=Backbone.Model.extend({
defaults:{name:"susan",age:"18"},
change_name:function(){
console.log("name has changed");
}
});
var user=new User();
var obj=_.extend({},Backbone.Events);
obj.listenTo(user,"change:name",user.change_name);
user.set("name","loly");

事件与视图

var User=Backbone.Model.extend({
defaults:{
name:'susan',
age:18}
});
var UserView=Backbone.View.extend({
tagName:'span',
initialize:function(){
this.listenTo(this.model,'change:name',this.show);
},
show:function(){
this.$el.text('show').appendTo('body');
}
});
var user=new User();
var userview=new UserView({model:user,});
user.set('name','lucy');

运行结果是body添加了一个span标签:<span>show</span>

Backbone学习记录(4)的更多相关文章

  1. Backbone学习记录(7)

    事件委托 <form> <input type="text" class="txt"> <input type="but ...

  2. Backbone学习记录(6)

    路由 backbone将路由规则和一个方法名绑定到一起,来控制单页的hash,以及单页的前进后退. var UserRouter = Backbone.Router.extend({ routes: ...

  3. Backbone学习记录(5)

    数据与服务器 var User=Backbone.Model.extend({ defaults:{ name:'susan', age:18 }, url:'/user'//数据提交的路径 }); ...

  4. Backbone学习记录(3)

    创建视图 同前面创建模型和集合的方式一样,Backbone.View.extend()即可创建视图 var UserView=Backbone.View.extend(); var view1=new ...

  5. Backbone学习记录(2)

    创建一个集合 1)new Backbone.Collection()方式 var user=new Backbone.Model({'name':'susan'}); var list=new Bac ...

  6. Backbone学习记录(1)

    去年买的<基于MVC的javascript Web富应用开发>,拖到现在还没看完,作者介绍了三个MVC框架,Spine ,backbone和javascriptMVC.1和2在国内的流行度 ...

  7. Backbone 学习笔记

    Backbone 是一款基于模型-视图-控制器 MVC 模式的轻量级javascript 框架 ,可以用来帮助开发人员创建单页Web应用. 借助Backbone 我们可以使用REST的方式来最小化客户 ...

  8. Quartz 学习记录1

    原因 公司有一些批量定时任务可能需要在夜间执行,用的是quartz和spring batch两个框架.quartz是个定时任务框架,spring batch是个批处理框架. 虽然我自己的小玩意儿平时不 ...

  9. Java 静态内部类与非静态内部类 学习记录.

    目的 为什么会有这篇文章呢,是因为我在学习各种框架的时候发现很多框架都用到了这些内部类的小技巧,虽然我平时写代码的时候基本不用,但是看别人代码的话至少要了解基本知识吧,另外到底内部类应该应用在哪些场合 ...

随机推荐

  1. xamarin.android Activity之间跳转与传值

    前言 由于需要,所以接触到这个新的安卓开发模式,我会把我的学习经历全都记录下来,希望对大家有用. 导读 关于Activity,学习过安卓的人也应该明白什么是Activity,推荐新手去看YZF的这篇文 ...

  2. 基于Ubuntu 14.04 LTS编译Android4.4.2源码

    版权声明:本文为博主原创文章,未经博主同意不得转载. https://blog.csdn.net/gobitan/article/details/24367439 基于Ubuntu 14.04 LTS ...

  3. oracle服务丢失的处理方法之OracleServiceORCL不存在示例

    oracle服务是oracle数据库的重要组成部分,下面就教您oracle服务丢失的处理方法,如果您之前遇到过oracle服务丢失的问题,不妨一看. 今天发现数据库服务器上的所有oracle服务都丢失 ...

  4. 装饰器模式(IO流案例)

    装饰器模式,也成为包装模式,顾名思义,就是对已经存在的某些类进行装饰,以此来扩展一些功能.其结构图如下: Component为统一接口,也是装饰类和被装饰类的基本类型. ConcreteCompone ...

  5. e.target与e.currentTarget的区别

    在DOM事件对象中有两个属性总是时不时的困扰我,就是target和currentTarget,有时候很迷惑分不清两者的区别,因此有必要把这两个属性好好梳理一下,加深理解,以便日后的查询. MDN中对t ...

  6. iOS字符串的各种用法(字符串插入、字符串覆盖、字符串截取、分割字符串)

    NSString* str=@"hello";//存在代码区,不可变 NSLog(@"%@",str); //1.[字符串插入] NSMutableString ...

  7. hdu 5615 Jam's math problem(十字相乘判定)

    d. Jam有道数学题想向你请教一下,他刚刚学会因式分解比如说,x^2+6x+5=(x+1)(x+5) 就好像形如 ax^2+bx+c => pqx^2+(qk+mp)x+km=(px+k)(q ...

  8. 如何在chrome上设置Bing为默认搜索引擎,在设置中无法直接设置

  9. DFS Used%: NaN%问题

    一.问题描述: [root@master sbin]# hdfs dfsadmin -report Configured Capacity: 0 (0 B) Present Capacity: 0 ( ...

  10. iOS 生成随机数

    arc4random 1.获取一个随机整数范围在:[0,100)包括0,不包括100 int x = arc4random() % 100; 2.  获取一个随机数范围在:[500,1000],包括5 ...