easyUI之为splitbuuton绑定事件

通过easyUI可以很迅速的创建一个分割按钮,但是easyUI没有为splitbutton封装onClick事件,这里我们谈下如何为它添加单击事件。

第一种,在标签内添加onClick,如下:

<a href="javascript:void(0)" id="sb" class="easyui-splitbutton" data-options="menu:'#mm',iconCls:'icon-ok'" οnclick="show('OK')">Ok</a>
<div id="mm" style="width:100px;">
<div data-options="iconCls:'icon-ok'" οnclick="show('OK')">Ok</div>
	<div data-options="iconCls:'icon-cancel'" οnclick="show('error')">Cancel</div>
</div>

function show(name){
	alert(name);
}

第二种,在标签内添加id或class,如下:

<a href="javascript:void(0)" id="sb" class="easyui-splitbutton OK" data-options="menu:'#mm',iconCls:'icon-ok'">Ok</a>
<div id="mm" style="width:100px;">
	<div data-options="iconCls:'icon-ok'" class="OK">Ok</div>
	<div data-options="iconCls:'icon-cancel'" class="Cancel">Cancel</div>
</div>

$(".OK").bind("click",function(){
	alert("OK")
})
			
$(".Cancel").bind("click",function(){
	alert("Cancel")
})

以上两种方法都不可避免的存在一定缺陷,如第一种使用onClick,容易暴露自己的接口,使不法分子在外部直接修改我们的接口;第二种,过于死板,不能动动态增加的元素绑定事件。所以,我比较赞成使用下面这种方法,即通过事件委托添加事件。

第三种,事件委托,如下:

<a href="javascript:void(0)" id="sb" class="easyui-splitbutton OK" data-options="menu:'#mm',iconCls:'icon-ok'">Ok</a>
<div id="mm" style="width:100px;">
	<div data-options="iconCls:'icon-ok'" class="OK">Ok</div>
	<div data-options="iconCls:'icon-cancel'" class="Cancel">Cancel</div>
</div>

$("#mm").bind("click",function(e){
	var classname = e.target.className;
	if(classname.indexOf("OK") > -1)
		alert("OK");
	if(classname.indexOf("Cancel") > -1)
	<span style="white-space:pre">	</span>alert("Cancel");
})

下面是经过easyUI解析后的html代码:


可以很明闲的发现,解析后的html与我们自己写的有很大的不同。


经过实验发现,在第三种方法中,将事件委托用与easyUI上一起使用时有bug存在,似乎是easyUI禁止了事件冒泡,有兴趣的同学可以深入探究下,互相交流。


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

逛街的猫啊

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值