2011-08-09 19 views
9

Estoy tratando de agregar las identificaciones, que son los valores $ hexcode del html span a una matriz. ¿Cómo hago esto con jQuery? Eventualmente, voy a tener que tomar estos valores de código hexadecimal y hacerlos coincidir con un índice de color.jQuery - agregando elementos en una matriz

<?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'));  
    }); 
}); 

¡Gracias de antemano!

+0

ve bien para mí. Lo que no funciona? – Phil

+0

¿Qué problema tienes? ¿Qué no está funcionando? – jergason

Respuesta

23

Pruebe esto, al final de cada bucle, la matriz de ids contendrá todos los códigos hexadecimales.

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

¡Gracias! ¿Cuál es una forma fácil de verificar/imprimir mi matriz? – Richard

+0

console.log (ids) si está en Chrome o Firebug en Firefox lo registrará en la consola de desarrollador. – jergason

+0

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

2
var ids = []; 

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

     ids.push(this.id);  
    }); 
}); 
Cuestiones relacionadas