繁体   English   中英

jQuery Click函数可在Firefox中运行,但不能在Chrome / Safari中运行

[英]jQuery Click function working in Firefox but not Chrome/Safari

我有一个按钮,可调整div的边距。 我有一个将进度条的宽度转换为百分比的函数。 然后,根据该条百分比,单击下一个或上一个按钮时,将应用适当的边距。

这在Firefox中工作正常,没有引发任何错误,但是在Safari和Chrome中,除了识别出已单击之外,它根本不起作用。 进度条将不会移动,因此widthPerc函数似乎有问题,因为它没有超出条件。 我没有写函数(可以在这里找到-jQuery,如果宽度等于百分比

我自己的点击功能如下-

$.fn.widthPerc = function() {
    var parent = this.parent();
    return ~~((this.width() / parent.width()) * 100) + '%';
};
$('.next-q').not('.two-questions .next-q').click(function() {
    var container = $(this).parents().eq(2);
    var questions = container.find('.questions');
    var progress = container.find('.form-progress .bar');
    var prev = container.find('.prev-q');
    var prevone = container.find('.question-steps.questions-one .prev-q');
    var prevs = container.find('.prev-s');
    var complete = container.find('.complete-q, .next-s');
    if (progress.widthPerc() === '66.66%') {
        progress.animate({
            width: '-=33.33%',
        }, 400);
        questions.css({
            'margin-left': '-100%'
        });
        prevs.fadeOut('400', function() {
            prev.fadeIn('400');
        });
        prevone.fadeIn('400');
    } else if (progress.widthPerc() === '33.33%') {
        progress.animate({
            width: '-=33.33%',
        }, 400);
        questions.css({
            'margin-left': '-200%'
        });
        $(this).fadeOut('400', function() {
            complete.fadeIn('400');
        });
    }
});

您的widthPerc函数可能返回的浮点数的精度比两位小数点的精度更高,因此可能类似于66.666667% 比较宽度百分比时,请尝试使用实际数字而不是字符串,并尝试对数字进行舍入以解决精度上的细微差异。 例如:

$.fn.widthPerc = function() {
    var parent = this.parent();
    return Math.round10(this.width() / parent.width() * 100, -2);
};

然后进行以下比较:

if (progress.widthPerc() >= 33.33) {
    // do stuff
}

解决了这个问题。 Chrome和Safari将值四舍五入为66%或33%,并删除了小数位。 将条件更改为progress.widthPerc() >= '66%'

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM