比如有一个slide的jquery插件,页面打开就对dom进行了绑定。
<div class="expert">
<div class="expert-list">
<ul>
<li class="expert-item">
<a href="#">
<img src="./imgs/expert1.jpg" />
</a>
</li>
<li class="expert-item">
<a href="#">
<img src="./imgs/expert2.jpg" />
</a>
</li>
</ul>
<a class="prev" href="javascript:void(0)"></a>
<a class="next" 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",autoPlay: true});
$(window).resize(function () {
$(".expert").empty();
//这里只需添加html结构,clone()好像会把行内样式也拷贝了。
$(".expert").append(expert.html());
$(".expert-list").slide({mainCell: "ul",autoPlay: true});
});
</script>
此方法的效率并不怎么高。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。