tinyEmitter
function tinyEmitter() {
}
tinyEmitter.prototype.on = function(evtype, fn) {
this._events = this._events || {};
this._events[evtype] = this._events[evtype] || [];
if (this._events[evtype].indexOf(fn) !== -1) return;
this._events[evtype].push(fn);
}
tinyEmitter.prototype.off = function(evtype, fn) {
this._events = this._events || {};
if (evtype in this._events === false) return;
fn && this._events[evtype].splice(this._events[evtype].indexOf(fn), 1);
!fn && delete this._events[evtype];
}
tinyEmitter.prototype.emit = function(evtype) {
this._events = this._events || {};
var self = this, args = [].slice.call(arguments, 1);
if (evtype in this._events === false) return;
this._events[evtype].forEach(function(fn, i) {
fn.apply(self, args);
});
}
tinyEmitter.eventify = function(Klass) {
Klass.prototype = Object.create(Klass.prototype);
for (var attr in tinyEmitter.prototype) {
Klass.prototype[attr] = tinyEmitter.prototype[attr]
}
return Klass;
}
tinyScroll
function tinyScroll() {
}
tinyEmitter.eventify(tinyScroll);
tinyScroll.prototype.init = function() {
var self = this;
self.checkDir();
}
tinyScroll.prototype.checkDir = function(e) {
var self = this, scrollTop = self.scrollTop = self.scrollTop || document.body.scrollTop;
if (scrollTop > document.body.scrollTop) {
self.emit('up', e);
}
if (scrollTop < document.body.scrollTop) {
self.emit('down', e);
}
self.emit('scroll', e);
}
// use
var s = new tinyScroll();
s.on('down', function() {
console.log('down...');
});
最后编辑于 :
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。