it-swarm.it

jQuery conta il numero di div con una certa classe?

Considerando qualcosa del genere;

<div class="wrapper">
    <div class="item"></div>
    <div class="item"></div>
    <div class="item"></div>
    <div class="item"></div>
    <div class="item"></div>
</div>

Come potrei, usando jQuery (o semplicemente JS, se è più breve - ma ne dubito) conta il numero di div con la classe "item"? In questo esempio, la funzione dovrebbe restituire 5, in quanto vi sono 5 div con la classe articolo.

Grazie!

48
user825286

Puoi usare jquery .length property

var numItems = $('.item').length;
107
Brian Glaz

Per prestazioni migliori dovresti usare:

var numItems = $('div.item').length;

Dal momento che cercherà solo gli elementi div in DOM e sarà veloce.

Suggerimento: using size() invece di length proprietà significa un passaggio aggiuntivo nell'elaborazione poiché SIZE() utilizza la proprietà length nella definizione della funzione e restituisce il risultato.

17
Ghazanfar Mir

È possibile utilizzare la proprietà jQuery.children.

var numItems = $('.wrapper').children('div').length;

per ulteriori informazioni, consultare http://api.jquery.com/

10
Nikhil salwe

Ho appena creato questa funzione js usando la funzione jQuery size http://api.jquery.com/size/

function classCount(name){
  alert($('.'+name).size())
}

Segnala il numero di volte in cui il nome della classe si verifica nel documento.

2
Vlad

E per la semplice risposta se qualcuno potrebbe essere interessato;

var count = document.getElementsByClassName("item");

Saluti.

Riferimento: https://www.w3schools.com/jsref/met_document_getelementsbyclassname.asp

1
Pax Vobiscum
<!DOCTYPE html>
    <html>
    <head>
        <title></title>
        <style type="text/css">
            .test {
                background: #ff4040;
                color: #fff;
                display: block;
                font-size: 15px;
            }
        </style>
    </head>
    <body>
        <div class="test"> one </div>
        <div class="test"> two </div>
        <div class="test"> three </div>
        <div class="test"> four </div>
        <div class="test"> five </div>
        <div class="test"> six </div>
        <div class="test"> seven </div>
        <div class="test"> eight </div>
        <div class="test"> nine </div>
        <div class="test"> ten </div>
        <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
        <script type="text/javascript">
        $(document).ready(function () {
            //get total length by class
            var numItems = $('.test').length;
            //get last three count
            var numItems3=numItems-3;         


            var i = 0;
            $('.test').each(function(){
                i++;
                if(i>numItems3)
                {

                    $(this).attr("class","");
                }
            })
        });
    </script>
    </body>
    </html>
0
Pratik Shah