jquery 插件重新绑定的处理方法分析

比如有一个slide的jquery插件,页面打开就对dom进行了绑定。

<div> <div> <ul> <li> <a href="#" > <img src="https://www.jb51.net/article/imgs/expert1.jpg" /> </a> </li> <li> <a href="#" > <img src="https://www.jb51.net/article/imgs/expert2.jpg" /> </a> </li> </ul> <a href="javascript:void(0)" ></a> <a href="javascript:void(0)" ></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相关内容感兴趣的读者可查看本站专题:《jQuery扩展技巧总结》、《jQuery常用插件及用法总结》、《jQuery切换特效与技巧总结》、《jQuery遍历算法与技巧总结》、《jQuery常见经典特效汇总》、《jQuery动画与特效用法总结》及《jquery选择器用法总结

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:http://www.heiqu.com/abec7ac73937379f2da23f9c35eb9561.html