jquery 插件重新绑定的处理方法分析
人气:0本文实例讲述了jquery 插件重新绑定的处理方法。分享给大家供大家参考,具体如下:
比如有一个slide的jquery插件,页面打开就对dom进行了绑定。
<div class="expert"> <div class="expert-list"> <ul> <li class="expert-item"> <a href="#" rel="external nofollow" rel="external nofollow" > <img src="./imgs/expert1.jpg" /> </a> </li> <li class="expert-item"> <a href="#" rel="external nofollow" rel="external nofollow" > <img src="./imgs/expert2.jpg" /> </a> </li> </ul> <a class="prev" href="javascript:void(0)" rel="external nofollow" rel="external nofollow" ></a> <a class="next" href="javascript:void(0)" rel="external nofollow" rel="external nofollow" ></a> </div> </div>
<script type="text/javascript"> $(".expert-list").slide({mainCell: "ul", autoPage: true, effect: "left", autoPlay: true}); </script>
现在需求是当窗口大小发生改变时,这个slide也会发生相应变化。
单纯的用jquery去控制expert-list、expert-item和img的宽、高效果并不怎么好。
想法是,解除expert-list上的slide插件绑定,然后在窗口大小改变的事件处理函数中再重新绑定,结果并没有找到解除绑定的方法。
笨办法是,先clone()一份,然后在把原先的dom删除再添加,再重新绑定。
<script type="text/javascript"> var expert = $(".expert").clone(); $(".expert-list").slide({mainCell: "ul", autoPage: true, effect: "left", autoPlay: true}); $(window).resize(function () { $(".expert").empty(); //这里只需添加html结构,clone()好像会把行内样式也拷贝了。 $(".expert").append(expert.html()); $(".expert-list").slide({mainCell: "ul", autoPage: true, effect: "left", autoPlay: true}); }); </script>
此方法的效率并不怎么高。
希望本文所述对大家jQuery程序设计有所帮助。
您可能感兴趣的文章:
- Json2Template.js 基于jquery的插件 绑定JavaScript对象到Html模板中
- 一个可绑定数据源的jQuery数据表格插件
- Angular指令封装jQuery日期时间插件datetimepicker实现双向绑定示例
- Jquery 模板数据绑定插件的使用方法详解
- jquery弹窗插件colorbox绑定动态生成元素的方法
- Vue.js列表渲染绑定jQuery插件的正确姿势
- jQuery给动态添加的元素绑定事件的方法
- jquery移除、绑定、触发元素事件使用示例详解
- JQuery中绑定事件(bind())和移除事件(unbind())
- jQuery事件的绑定、触发、及监听方法简单说明
- jQuery事件绑定和委托实例
- jQuery事件绑定on()、bind()与delegate() 方法详解
加载全部内容