兼容火狐浏览器,jq animate backgroundPosition

本文介绍了一个自定义的backgroundPosition插件,旨在解决Firefox浏览器中background-position属性不完全支持的问题,通过调整代码使其兼容各种背景位置设置,并展示了如何在jQuery中使用此插件实现动画效果。

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

animate 是jq的一个非常好,用的一个动画效果的一种方法。 但火狐浏览器中 background-position-y、background-position-x、还有jq的 backgroundPosition不完善。如是就想修改一个backgroundPosition插件来兼容。

backgroundPosition 插件代码

(function($) {
    $.extend($.fx.step,{
        backgroundPosition: function(fx) {
            if (typeof fx.start == "number" && typeof fx.end == 'string') {
                var start = $.css(fx.elem,'backgroundPosition');
                start = start.split("px");
                if (start[2] == undefined) {
                    start = start[0].split("%");
                }
                fx.start = [parseInt(start[0]), parseInt(start[1])]

                var end = fx.end.split("px");
                fx.end = [parseInt(end[0]),parseInt(end[1])];

            }

            var nowPosX = [];
            nowPosX[0] = ((fx.end[0] - fx.start[0]) * fx.pos) + fx.start[0] + "px";
            nowPosX[1] = ((fx.end[1] - fx.start[1]) * fx.pos) + fx.start[1] + "px";

            fx.elem.style.backgroundPosition = nowPosX[0]+' '+nowPosX[1];

        }
    });
})(jQuery);

使用方法

$(this).animate({"backgroundPosition": "0px 50px"},200);
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值