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

本文探讨了一个使用jQuery实现的Slide插件,在页面加载时对DOM元素进行绑定的问题。当窗口尺寸发生变化时,如何使Slide插件能够响应式地调整其布局成为一个挑战。文中提出了一种通过克隆DOM元素并重新绑定插件的方式来实现这一目标的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

比如有一个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", 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>
此方法的效率并不怎么高。

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值