@user_tm

Почему не полностью отображаются числа?

Почему не полностью отображаются числа?
Разрабатывается секцию на сайте где отображаются инфа о компании в цифрах. Для это скачал скрипт "АНИМАЦИЯ ЧИСЕЛ ПРИ ПРОКРУТКЕ НА JQUERY" (ссылка на всякий случай https://bayguzin.ru/main/skriptyi/interfejs/animac...)

Скачал, подключил, анимация, все работает, но почему то не полностью отображаются числа. Например водном показателе должно быть число 998 870 981, а отображается только первые три, т. е. 998, так же в другом показателе должно быть 1 044 667 000, а отображается только один первый знак "1", за то в двух других показателях где числа меньше четырех знаком отображаться в полной мере 85, 19.

612bab7ce35a0413913109.jpeg

вот html код
<h1 class="factor-title">О Кредитном Товариществе в цифрах "ХХХХХХ" в цифрах</h1>
					
					        <div class="benefits__inner">
					            
					            <div class="benefits__element">		                
					                <p class="benefits__number">998 870 981</p>
					                <p class="benefits__title">ТЕНГЕ ССУДНЫЙ ПОРТФЕЛЬ</p>
					            </div>
					            <div class="benefits__element">		                
					                <p class="benefits__number">85</p>
					                <p class="benefits__title">ЗАЕМЩИКА/p>
					            </div>
					            <div class="benefits__element">		                
					                <p class="benefits__number">19</p>
					                <p class="benefits__title">ЛЕТ СУЩЕСТВУЕМ</p>
					            </div>
					            <div class="benefits__element">		                
					                <p class="benefits__number">1 044 667 000</p>
					                <p class="benefits__title">ТЕНГЕ РАЗМЕР КРЕДИТНОЙ ЛИНИИ</p>
					            </div>
					        </div>

вот код js файла "custom.js"
$(document).ready(function () {

    var show = true;
    var countbox = ".benefits__inner";
    $(window).on("scroll load resize", function () {
        if (!show) return false; // Отменяем показ анимации, если она уже была выполнена
        var w_top = $(window).scrollTop(); // Количество пикселей на которое была прокручена страница
        var e_top = $(countbox).offset().top; // Расстояние от блока со счетчиками до верха всего документа
        var w_height = $(window).height(); // Высота окна браузера
        var d_height = $(document).height(); // Высота всего документа
        var e_height = $(countbox).outerHeight(); // Полная высота блока со счетчиками
        if (w_top + 2000 >= e_top || w_height + w_top == d_height || e_height + e_top < w_height) {
            $('.benefits__number').css('opacity', '1');
            $('.benefits__number').spincrement({
                thousandSeparator: "",
                duration: 3000
            });

            show = false;
        }
    });

});

вот код другого js файла
!function(t){t.extend(t.easing,{spincrementEasing:function(t,a,e,n,r){return a===r?e+n:n*(-Math.pow(2,-10*a/r)+1)+e}}),t.fn.spincrement=function(a){function e(t,a){if(t=t.toFixed(a),a>0&&"."!==r.decimalPoint&&(t=t.replace(".",r.decimalPoint)),r.thousandSeparator)for(;o.test(t);)t=t.replace(o,"$1"+r.thousandSeparator+"$2");return t}var n={from:0,to:null,decimalPlaces:null,decimalPoint:".",thousandSeparator:",",duration:1e3,leeway:50,easing:"spincrementEasing",fade:!0,complete:null},r=t.extend(n,a),o=new RegExp(/^(-?[0-9]+)([0-9]{3})/);return this.each(function(){var a=t(this),n=r.from;a.attr("data-from")&&(n=parseFloat(a.attr("data-from")));var o;if(a.attr("data-to"))o=parseFloat(a.attr("data-to"));else if(null!==r.to)o=r.to;else{var i=t.inArray(r.thousandSeparator,["\\","^","$","*","+","?","."])>-1?"\\"+r.thousandSeparator:r.thousandSeparator,l=new RegExp(i,"g");o=parseFloat(a.text().replace(l,""))}var c=r.duration;r.leeway&&(c+=Math.round(r.duration*(2*Math.random()-1)*r.leeway/100));var s;if(a.attr("data-dp"))s=parseInt(a.attr("data-dp"),10);else if(null!==r.decimalPlaces)s=r.decimalPlaces;else{var d=a.text().indexOf(r.decimalPoint);s=d>-1?a.text().length-(d+1):0}a.css("counter",n),r.fade&&a.css("opacity",0),a.animate({counter:o,opacity:1},{easing:r.easing,duration:c,step:function(t){a.html(e(t*o,s))},complete:function(){a.css("counter",null),a.html(e(o,s)),r.complete&&r.complete(a)}})})}}(jQuery);
  • Вопрос задан
  • 137 просмотров
Решения вопроса 1
Rsa97
@Rsa97
Для правильного вопроса надо знать половину ответа
Потому что скрипт ожидает число, а получает строку с пробелами между цифрами. Соответственно, при преобразовании в число всё после первого пробела отбрасывается.
Ответ написан
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы