triggerHandler写法怎么理解

triggerHandler写法怎么理解

这里的写法以前从来没接触过,请问怎么理解,还有这里的triggerHandler的作用是什么?
wrap
	.on('move_prev',function(){
		if(current<=0){
			current = size;
		}
		current = current - 1 ;
		wrap.triggerHandler('move_to',current);
	})
	.on('move_next',function(){
		if( current >= size-1){
			current = -1;
		}
		current = current + 1 ;
		wrap.triggerHandler('move_to',current);
	})
	.on('move_to',function(evt,index){
		wrap.css('left',index*width*-1);
		tips.removeClass('item_focus').eq(index).addClass('item_focus');
	})
	.on('auto_move',function(){

		setInterval(function(){
			enableAuto && wrap.triggerHandler('move_next');
		},2000);

	})
	.triggerHandler('auto_move');

	//	事件
	btn_prev.on('click',function(){
		wrap.triggerHandler('move_prev');
	});
	btn_next.on('click',function(){
		wrap.triggerHandler('move_next');
	});
	tips.on('click',function(){
		var index = $(this).index();
		wrap.triggerHandler('move_to',index);
	})

}


正在回答 回答被采纳积分+1

登陆购买课程后可参与讨论,去登陆

2回答
提问者 慕函数3468989 2018-10-12 14:11:53

请问能通俗一点回答吗,不是很懂

妮可妮可妮_ 2018-10-12 14:09:11

wrap.on('move_prev', function() {}) 这种写法是事件代理的形式,事件代理就是把自己的事件给父元素,让他帮忙调用。因为子元素可能是我们从js中添加dom元素的,dom中本来就没有写,所以当页面没有加载完的时候,直接给子元素调用事件就会报错,说找不到这个元素。所以要用代理的形式给父元素。

triggerHandler() 方法触发被选元素的指定事件类型。但不会执行浏览器默认动作, 比如表单提交,也不会产生事件冒泡.只影响第一个匹配元素。

语法:$(selector).triggerHandler(event,[param1,param2,...])

http://img1.sycdn.imooc.com//climg/5bc039490001a11004780093.jpg

祝学习愉快!


  • 提问者 慕函数3468989 #1
    请问能通俗一点回答吗,不是很懂
    2018-10-12 14:12:32
  • 妮可妮可妮_ 回复 提问者 慕函数3468989 #2
    事件代理就是将自己的时间委托给父元素,它们父级代为执行事件. triggerHandler() 方法用来触发被选元素的指定事件类型。 如果同学还有哪里不理解可以针对性的指出来哦~这样老师才能高效的帮你解决疑惑
    2018-10-12 14:46:14
问题已解决,确定采纳
还有疑问,暂不采纳

恭喜解决一个难题,获得1积分~

来为老师/同学的回答评分吧

0 星
前端小白入门系列课程
  • 参与学习           人
  • 提交作业       11218    份
  • 解答问题       36713    个

从一个不会编程的小白到一个老司机是需要过程的,首先得入门,学习基础知识,然后才能进阶,最后再到精通,本专题是你走进前端世界的不二选择!

了解课程
请稍等 ...
意见反馈 帮助中心 APP下载
官方微信

在线咨询

领取优惠

免费试听

领取大纲

扫描二维码,添加
你的专属老师