How to move the tags dynamically generated by the for loop, and add the previous movement distance to each label movement distance?

for example, dynamically create 10 span tag loops in div

<div class="square">
</div>
<script>
    var str="<span></span>";
    for(var i=0;i<10;iPP){
        $(".square").append(str);
    }
</script>

.

 .square{
        width:400px;
        height: 200px;
        border:1px solid red;
        position: relative;
    }
    .square span{
        width:10px;
        height:10px; 
        background:blue;
        position: absolute;
        bottom:0;
    }
    .square span:nth-child(2){
        left:12px;
    }
    .square span:nth-child(3){
        left:24px;
        background:red;
    }
    .square span:nth-child(4){
        left:36px;
    }

it seems that the span created are all stacked together. Now I want to move each tag to the left, and the tag behind it and overlay the previous movement distance. I use css to move each tag left, but this is too cumbersome. It is not exhausting to cycle around to generate more than 30 tags. How should js dynamic write forEach? Solve?

Mar.04,2021

for (var i = 0; i < 10; iPP) {
    $(".square").append('<span style="left:' + i * 12 + 'px"></span>');
}

contribute a naughty way to write:

   

MySQL Query : SELECT * FROM `codeshelper`.`v9_news` WHERE status=99 AND catid='6' ORDER BY rand() LIMIT 5
MySQL Error : Disk full (/tmp/#sql-temptable-64f5-1b3029d-e240.MAI); waiting for someone to free some space... (errno: 28 "No space left on device")
MySQL Errno : 1021
Message : Disk full (/tmp/#sql-temptable-64f5-1b3029d-e240.MAI); waiting for someone to free some space... (errno: 28 "No space left on device")
Need Help?