重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
1、unbind()方法
我们拥有十载网页设计和网站建设经验,从网站策划到网站制作,我们的网页设计师为您提供的解决方案。为企业提供成都网站建设、成都网站设计、微信开发、小程序设计、移动网站建设、H5高端网站建设、等业务。无论您有什么样的网站设计或者设计方案要求,我们都将富于创造性的提供专业设计服务并满足您的需求。
unbind(type [,data]) //data是要移除的函数
$('#btn').unbind("click"); //移除click
$('#btn').unbind(); //移除所有
2、卸载事件off()方法
通过.on()绑定的事件处理程序
通过off() 方法移除该绑定
//绑定2个事件
$("elem").on("mousedown mouseup",fn)
//删除一个事件
$("elem").off("mousedown")
//删除所有事件
$("elem").off("mousedown mouseup")
//快捷方式删除所有事件,这里不需要传递事件名了,节点上绑定的所有事件讲全部销毁
$("elem").off()
$("#element").click(function(){}); //绑定点击事件函数
$("#element").unbind(); //解绑点击事件
先简单说下jQuery绑定和解绑点击事件的方法
$("#element").click(function(){}); //绑定点击事件函数
$("#element").unbind(); //解绑点击事件
$("#element").click(function(){}); //绑定其它函数
即,要对一个绑定过点击事件的元素绑定其它函数,需先对其解绑。
上面的代码看起来好简单,但是实际应用中却要复杂的多。举一个项目中的实例吧。
两个显示标签云的DIV,DIV1显示选中的标签,DIV2显示可选的标签。DIV2中的任一个标签被点中后会从DIV2中消失并添加到DIV1中,再在DIV1点击它时,它又会回到DIV2。两个DIV中的标签总数、单个标签的内容保持不变。这个效果我花了差不多一个半小时才搞定,就是因为对jQuery绑定和解绑点击事件理解的不到位。
我最开始的理解是:当一个标签从DIV1中移除并添加到DIV2中时,其原来绑定的所有事件都会消失,我可以从DIV2中析取这个标签并给它绑定新的点击事件。结果是:再点击它时它并没有回到DIV1,而是还是在DIV2中,只是位置被移到了最后。我误以为这个标签还属于DIV1,殊不知不是DIV的归属问题,而是点击事件的绑定问题。
你是美工吗?这个效果做程序的做起来比较好做,你的标签最好都加上唯一标识,ID,当你点击这的时候调用id,然后存在一个input里面,用逗号隔开存成字符串,例如:mark1,mark2,mark3
这样存,然后当超出5个的时候你split拆分成数组,去掉第一个元素吧新的ID再组成新的字符串
jQuery是用原生javascript封装出来的一个基本框架,因为容易上手跟好用是很多初级开发的首选技术框架,在里面有几个方法可以解除绑定事件:
①用on()绑定事件之后可以用off()方法来解除绑定onlick事件,这个种绑定解绑方法是推荐使用的
②用bind()绑定事件之后可以用unbind()方法来解除绑定onclick事件,可以使用
③用live()绑定事件之后可以用die()方法来接触绑定onclick事件,可以使用
④但是第一种方法是结合下面两种封装出来的新的方法,更方便,还处理了下面两种方法带来的弊端