2011-08-09 28 views
9

Próbuję dodać identyfikatory, które są wartościami $ hexcode z zakresu html do tablicy. Jak to zrobić z jQuery? W końcu będę musiał pobrać te wartości kodu szesnastkowego i dopasować je do indeksu kolorów.jQuery - dodawanie elementów do tablicy

<?php 
// display every color in the world 

$r = 0; 
$g = 0; 
$b = 0; 
$i = 0; 
$step = 16; 

for($b = 0; $b < 255; $b+=$step) { 
    for($g = 0; $g < 255; $g+=$step) { 
     for($r = 0; $r < 255; $r+=$step) { 
     $hexcolor = str_pad(dechex($r), 2, "0", STR_PAD_LEFT).str_pad(dechex($g), 2, "0", STR_PAD_LEFT).str_pad(dechex($b), 2, "0", STR_PAD_LEFT); 
     echo '<span class="color_cell" id="'.$hexcolor.'" style="width: 5px; height: 5px; background-color:#'.$hexcolor.'; border: 1px dotted;">&nbsp;</span>' 

     if($i%256 == 0) { 
      echo "<br />"; 
     } 
     $i++; 
     } 
    } 

} 
?> 
<script src="jquery-1.6.2.js"></script> 
<script type="text/javascript"> 

var ids = []; 

    $(document).ready(function($) {  
    $(".color_cell").bind('click', function() { 
     alert('Test'); 
     //how do i add the ID (which is the $hexcolor into this array ids[]? 
     ids.push($(this).attr('id'));  
    }); 
}); 

Z góry dziękuję!

+0

Wygląda w porządku dla mnie. Co nie działa? – Phil

+0

Jaki problem napotykasz? Co nie działa? – jergason

Odpowiedz

23

Spróbuj tego, na końcu każdej pętli tablica ids będzie zawierać wszystkie kody szesnastkowe.

var ids = []; 

    $(document).ready(function($) { 
    var $div = $("<div id='hexCodes'></div>").appendTo(document.body), code; 
    $(".color_cell").each(function() { 
     code = $(this).attr('id'); 
     ids.push(code); 
     $div.append(code + "<br />"); 
    }); 



}); 
+0

Dzięki! Jaki jest łatwy sposób sprawdzenia/wydrukowania mojej tablicy? – Richard

+0

console.log (ids), jeśli jesteś w przeglądarce Chrome lub Firebug w Firefoksie, zalogujesz go do konsoli programisty. – jergason

+0

var divnew = document.createElement ("div"); dla (var i = 0; i '; } $ ("body"). Append (divnew); –

2
var ids = []; 

    $(document).ready(function($) {  
    $(".color_cell").bind('click', function() { 
     alert('Test'); 

     ids.push(this.id);  
    }); 
}); 
Powiązane problemy