0

I am trying to build a circle bar with jQuery, but there is one error showing in the console, which cannot be solved. Have googled around, but nothing happened. Does anyone know how I can fixed this error? It is right that the code cannot run by snippet, because of this. So please do not downvote this, it is part of this issue.

$(document).ready(function ($) {
    function animateElements() {
        $('.progressbar').each(function () {
            var elementPos = $(this).offset().top;
            var topOfWindow = $(window).scrollTop();
            var percent = $(this).find('.circle').attr('data-percent');
            var percentage = parseInt(percent, 10) / parseInt(100, 10);
            var animate = $(this).data('animate');
            if (elementPos < topOfWindow + $(window).height() - 30 && !animate) {
                $(this).data('animate', true);
                $(this).find('.circle').circleProgress({
                    startAngle: -Math.PI / 2,
                    value: percentage,
                    thickness: 8,
                    fill: {
                        color: '#1B58B8'
                    }
                }).on('circle-animation-progress', function (event, progress, stepValue) {
                    $(this).find('div').text(String(stepValue.toFixed(2)).substr(2) + '%');
                }).stop();
            }
        });
    }

    // Show animated elements
    animateElements();
    $(window).scroll(animateElements);
});
.progressbar {
    display: inline-block;
    width: 100px;
    margin: 25px;
}
.circle {
    width: 100%;
    margin: 0 auto;
    margin-top: 10px;
    display: inline-block;
    position: relative;
    text-align: center;
}
.circle canvas {
    vertical-align: middle;
}
.circle div {
    position: absolute;
    top: 30px;
    left: 0;
    width: 100%;
    text-align: center;
    line-height: 40px;
    font-size: 20px;
}
.circle strong i {
    font-style: normal;
    font-size: 0.6em;
    font-weight: normal;
}
.circle span {
    display: block;
    color: #aaa;
    margin-top: 12px;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>

<div style="width:100%;height:500px;"></div>

<h3>Sed scelerisque</h3>

<div class="progressbar" data-animate="false">
    <div class="circle" data-percent="98">
        <div></div>
        <p>Quisque's</p>
    </div>
</div>
<div class="progressbar" data-animate="false">
    <div class="circle" data-percent="30">
        <div></div>
        <p>Maecenas</p>
    </div>
</div>
<div class="progressbar" data-animate="false">
    <div class="circle" data-percent="77">
        <div></div>
        <p>Pellentesque</p>
    </div>
</div>
<div class="progressbar" data-animate="false">
    <div class="circle" data-percent="49">
        <div></div>
        <p>Etiam sodales</p>
    </div>
</div>
<div style="width:100%;height:500px;"></div>
jbutler483
  • 24,074
  • 9
  • 92
  • 145
Front-end Developer
  • 400
  • 1
  • 6
  • 17

1 Answers1

2

It appears that you just need to include the jquery and circle progress js files via your html - i.e.

<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<script src="https://cdn.rawgit.com/kottenator/jquery-circle-progress/1.2.0/dist/circle-progress.js"></script>

See example below:

$(document).ready(function ($) {
    function animateElements() {
        $('.progressbar').each(function () {
            var elementPos = $(this).offset().top;
            var topOfWindow = $(window).scrollTop();
            var percent = $(this).find('.circle').attr('data-percent');
            var percentage = parseInt(percent, 10) / parseInt(100, 10);
            var animate = $(this).data('animate');
            if (elementPos < topOfWindow + $(window).height() - 30 && !animate) {
                $(this).data('animate', true);
                $(this).find('.circle').circleProgress({
                    startAngle: -Math.PI / 2,
                    value: percentage,
                    thickness: 8,
                    fill: {
                        color: '#1B58B8'
                    }
                }).on('circle-animation-progress', function (event, progress, stepValue) {
                    $(this).find('div').text(String(stepValue.toFixed(2)).substr(2) + '%');
                }).stop();
            }
        });
    }

    // Show animated elements
    animateElements();
    $(window).scroll(animateElements);
});
.progressbar {
    display: inline-block;
    width: 100px;
    margin: 25px;
}
.circle {
    width: 100%;
    margin: 0 auto;
    margin-top: 10px;
    display: inline-block;
    position: relative;
    text-align: center;
}
.circle canvas {
    vertical-align: middle;
}
.circle div {
    position: absolute;
    top: 30px;
    left: 0;
    width: 100%;
    text-align: center;
    line-height: 40px;
    font-size: 20px;
}
.circle strong i {
    font-style: normal;
    font-size: 0.6em;
    font-weight: normal;
}
.circle span {
    display: block;
    color: #aaa;
    margin-top: 12px;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<script src="https://cdn.rawgit.com/kottenator/jquery-circle-progress/1.2.0/dist/circle-progress.js"></script>
<div style="width:100%;height:500px;"></div>

<h3>Sed scelerisque</h3>

<div class="progressbar" data-animate="false">
    <div class="circle" data-percent="98">
        <div></div>
        <p>Quisque's</p>
    </div>
</div>
<div class="progressbar" data-animate="false">
    <div class="circle" data-percent="30">
        <div></div>
        <p>Maecenas</p>
    </div>
</div>
<div class="progressbar" data-animate="false">
    <div class="circle" data-percent="77">
        <div></div>
        <p>Pellentesque</p>
    </div>
</div>
<div class="progressbar" data-animate="false">
    <div class="circle" data-percent="49">
        <div></div>
        <p>Etiam sodales</p>
    </div>
</div>
<div style="width:100%;height:500px;"></div>
Sᴀᴍ Onᴇᴌᴀ
  • 8,218
  • 8
  • 36
  • 58