![](/img/trans.png)
[英]JQuery | click function not working in Firefox, but working in Chrome
[英]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.