BackboneJS 单次监听事件
2018-01-04 18:37 更新
描述
它与listenTo事件相同,但是会导致在回调函数被删除之前只发生一次listen。
语法
object.listenToOnce(other, event, callback)
参数
other:定义其他对象的名称。
event:它绑定一个对象。
callback:它是对代码的引用,并以对象作为上下文调用。
例
<!DOCTYPE html>
<head>
<title>Event Once Example</title>
<script src="https://code.jquery.com/jquery-2.1.3.min.js" type="text/javascript"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/underscore.js/1.8.2/underscore-min.js" type="text/javascript"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/backbone.js/1.1.2/backbone-min.js" type="text/javascript"></script>
</head>
<body>
<script type="text/javascript">
//Create an object 'myVal' and 'myVal1' and extend them using Backbone.Events method
var myVal = _.extend({name:'Saurav Ganguly'}, Backbone.Events);
var myVal1 = _.extend({name:'Sachin Tendulkar'}, Backbone.Events);
//created the 'listenMe' callback function and invoked when one object listen to particular event on another object
var listenMe = function(){
document.write("The value is: ");
document.write(this.name);
};
//The object 'myVal1' listen once for the 'listenMe' event triggered on object 'myVal'
myVal1.listenToOnce(myVal, 'listenMe', listenMe);
//The 'myVal' has no listenMe event and display the value of 'myVal1'
myVal.trigger('listenMe');
</script>
</body>
</html>
输出
让我们执行以下步骤,看看上面的代码如何工作:
- 将上面的代码保存在listentoonce.htm文件中。
- 在浏览器中打开此HTML文件。
The value is: Sachin Tendulkar
以上内容是否对您有帮助:
更多建议: