Foros del Web » Programando para Internet » PHP »

Factura con php y mysql

Estas en el tema de Factura con php y mysql en el foro de PHP en Foros del Web. Hola muchachos, estoy empezando con php y mysql y pues la verdad he tenido unos problemitas, que he ido solucionando, pero el que tengo ahora, ...
  #1 (permalink)  
Antiguo 09/01/2009, 12:38
 
Fecha de Ingreso: enero-2009
Mensajes: 7
Antigüedad: 15 años, 10 meses
Puntos: 0
Exclamación Factura con php y mysql

Hola muchachos, estoy empezando con php y mysql y pues la verdad he tenido unos problemitas, que he ido solucionando, pero el que tengo ahora, no le he podido encontrar solucion:

Tengo un formulario dinamico de una factura, es decir, le puedo ir agregando o borrando filas, porque es una factura que puede tener n (que no se sabe cuantos son) items que describen a n articulos (1 fila para cada articulo).

el problema es que no se como capturar los datos, ya que cada fila esta compuesta por 3 columnas (referencia, cantidad, descripcion) y pues si son 3 filas cada variable (columna) tendria que tener 3 datos, el caso es que lo he intentado de todas las formas que he sabido e investigado, y siempre la variable queda con el valor de la ultima fila.

Siempre he visto que concatenanlas variables en el vector manualmente, es decir con una cantidad fija de filas, pero eso no me sirve, lo que busco es como hacerlo dinamicamente es decir, sin tener un numero fijo de filas.

Espero haberme hecho entender

aca esta el codigo del formulario y la lectura de variables que he intentado hacer

Código HTML:
<form method="post" action="Registrar_T.php" name="outputForm1">
  <p>&nbsp;</p>
  <p>&nbsp;</p>
  <table id="tabla_1">
<thead>
<tr>
<th>Nº Referencia</th>
<th>Cantidad</th>

<th>Descripcion</th>
<th>&nbsp;</th>
</tr>
</thead>

<tbody>

<!-- Fila escondida, que va a llegar con un base 0 -->
<tr id="clonable" style="display:none">
<td><input type="text" name="referencia" /></td>
<td><input type="text" name="cantidad" /></td>

<td><input type="text" name="descripcion" /></td>
<td><a href="#" onClick="borraFila(this.parentNode.parentNode)">Eliminar</a></td>
</tr>
<!-- Esta fila va a ser la clonada -->

<tr id="tabla_1_fila_1">
<td><input type="text" name="referencia" /></td>
<td><input type="text" name="cantidad" /></td>
<td><input type="text" name="descripcion" /></td>
<td><a href="#" onClick="borraFila(this.parentNode.parentNode)">Eliminar</a></td>

</tr>

</tbody>

<tfoot>
<tr>
<td colspan="n">
<a href="javascript:agregaFila( 'tabla_1' );">Agregar Fila</a>
</td>
</tr>
</tfoot>

</table>

<input type="submit" name="submit" value="Aceptar">
</form>


<script>

function agregaFila( id ) {
var tabla = document.getElementById( id );
var tbody = document.getElementById( tabla.id ).tBodies[0];
var row = tbody.rows[0].cloneNode( true );
var id = 1;
while( document.getElementById( tabla.id+'_fila_'+id ) ) {
id++;
}
row.id = tabla.id+'_fila_'+id;
row.style.display = '';
tbody.appendChild( row );
}

function borraFila( fila ) {
var id = fila.id;
if( fila.parentNode.rows.length <= 2 ) return;
document.getElementById( id ).parentNode.removeChild( document.getElementById(id) );
}

</script> 
**php de la consulta***
Código PHP:
<?php
$f
=count($_POST['referencia']);
for (
$i=0;$i<count($_POST['referencia']);$i++) {
$cantidad $_POST["referencia"][$i];
//echo $cantidad;
}
//POR EL MOMENTO ESTE CODIGO NO INTERESA YA QUE PARA descripcion Y cantidad EL PROCESO SERI EL MISMO
//$cantidad = $_POST['cantidad'];
//$descripcion = $_POST['descripcion'];


//SI SE PUEDE UN AYUDADITA ACA CON LA INSERCION
//$sql = "INSERT INTO demo(numfactura, descripcion, cantidad) 
//VALUES ('$numfactura','$descripcion','$cantidad')";

//$result = mysql_query($sql);

?>
  #2 (permalink)  
Antiguo 09/01/2009, 12:49
Avatar de pateketrueke
Modernizr
 
Fecha de Ingreso: abril-2008
Ubicación: Mexihco-Tenochtitlan
Mensajes: 26.399
Antigüedad: 16 años, 7 meses
Puntos: 2534
Respuesta: Factura con php y mysql

he ahí tu error... entonces, no has leído lo suficiente del manual de PHP....


Referencia:

Variables Externas



para colocar como array un <input/> debes colocar en el name un identificador de tipo array ¿lo crees??

Código HTML:
<input name="foo[]" value="does"/> 
de esta manera, tienes múltiples campos relacionados por su name y al recibirlo en el PHP, es tan solo.... un array mas ¿listo??

inclusive, gracias al poder del HTML ... puedes asignar ID's al name, etc, etc...

Código HTML:
<input name="foo[1]"/>
<input name="foo[bar]"/>
<input name="foo[buzz][cola]"/> 
Código PHP:
print_r($_POST['foo']); 

esa es la clave, suerte!!
__________________
Y U NO RTFM? щ(ºдºщ)

No atiendo por MP nada que no sea personal.
  #3 (permalink)  
Antiguo 09/01/2009, 19:56
 
Fecha de Ingreso: enero-2009
Mensajes: 7
Antigüedad: 15 años, 10 meses
Puntos: 0
Respuesta: Factura con php y mysql

se supone que eso me debe imprimir todos los valores del array???

porque solo me imprime el primer valor y si le coloco un indice es deccir por ejemplo
print_r($_POST['foo [1]']);

no imprime nada
  #4 (permalink)  
Antiguo 09/01/2009, 19:58
Avatar de pateketrueke
Modernizr
 
Fecha de Ingreso: abril-2008
Ubicación: Mexihco-Tenochtitlan
Mensajes: 26.399
Antigüedad: 16 años, 7 meses
Puntos: 2534
Respuesta: Factura con php y mysql

mmm... si existen varios name="foo[]" si, es un array ... completamente seguro!!

nada de $_POST['foo[N]'] es una aberración, en su lugar (lógico) has esto... $_POST['foo']['bar']

osea, si el ejemplo es muy claro... o no??

Código HTML:
<input name="foo[1]"/>
<input name="foo[bar]"/>
<input name="foo[buzz][cola]"/> 
¿¿listo???
__________________
Y U NO RTFM? щ(ºдºщ)

No atiendo por MP nada que no sea personal.
  #5 (permalink)  
Antiguo 10/01/2009, 05:14
Avatar de colote  
Fecha de Ingreso: julio-2008
Ubicación: Rosario - Santa Fe - Argentina
Mensajes: 729
Antigüedad: 16 años, 4 meses
Puntos: 8
Respuesta: Factura con php y mysql

Hola amigo, creo tener la solucion a tu problema: Proba esto , lo que hace es agregar filas y borrarlas tambien, y le puse para que te muestro los datos que ingresaste !!!
Espero te sirva !!!
Código PHP:
<?php
if(isset($_POST['ok'])){

for (
$i=1;$i<=$_POST["var_cont"];$i++)
 {
echo 
"Numero de Fila: " ; echo $i;
echo 
"Codigo: ";  echo $_POST["code_$i"];
echo 
"Nombre: "; echo $_POST["name_$i"];
echo 
"Cantidad: "; echo $_POST["cant_$i"];echo "<br>";

 }

}
?>

<html>
<head>
<title>PRUEBA AGREGAR FILAS
</title>
</head>

<body>
<form id="form" name="form" action="<?php echo $_SERVER['PHP_SELF'];?>" method="post" onsubmit="asigna()">

<br>

<table border="1" id="tabla" bordercolor="#FFCC33" cellspacing="1">
<tr colspan="13" align="left">
<td align="center"><font color="1166FF" size="3"><b>EJEMPLO !!!</b></font></td>
</tr>
<tr align="center">
<td valign="top"><input type="button" name="b1" value="[+]" onClick="addRowX()">
<input type="button" name="b2" value="[-]" onClick="borrar()"></td>
<td><font color="blue" size="1">COD</font></td>
<td><font color="blue" size="1">NOMBRE</font></td>
<td><font color="blue" size="1">CANTIDAD</font></td>
</tr>

<tr>

<td><input type="text" size="4" name="code_1" /></td>
<td><input type="text" size="25" name="name_1"/></td>
<td><input type="text" size="8" name="cant_1"/></td>
<input type="hidden" name="var_cont">
</tr>
</table>


<table border="1" id="tabla_f2" bordercolor="#6B238E" align="center">
<tr>
<td><input type="submit" name="ok" id="ok" value="GUARDAR" /></td>
</tr>
</table>

</body>
</html>


<script language='JavaScript'>
var cont=1;
function addRowX()  //Esta la funcion que agrega las filas :
{

cont++;
var indiceFila=1;
myNewRow = document.getElementById('tabla').insertRow(-1);
myNewRow.id=indiceFila;
myNewCell=myNewRow.insertCell(-1);
myNewCell.innerHTML='<td><input type="text" size="4" name="code_'+cont+'" /></td>';
myNewCell=myNewRow.insertCell(-1);
myNewCell.innerHTML='<input type="text" size="25" name="name_'+cont+'"/>';
myNewCell=myNewRow.insertCell(-1);
myNewCell.innerHTML='<input type="text" size="8" name="cant_'+cont+'"/>';
indiceFila++;

}
//////////////Borrar() ///////////
function borrar() {
var table = document.getElementById('tabla');
if(table.rows.length > 3)
    {
    table.deleteRow(table.rows.length -1);
cont--;
    }
}

////////////FUNCION ASIGNA VALOR DE CONT PARA EL FOR DE MOSTRAR DATOS MP-MOD-TT////////
function asigna()
{
valor=document.form.var_cont.value=cont;
}
</script>
__________________
Mail: [email protected]
  #6 (permalink)  
Antiguo 11/01/2009, 18:34
 
Fecha de Ingreso: enero-2009
Mensajes: 7
Antigüedad: 15 años, 10 meses
Puntos: 0
Respuesta: Factura con php y mysql

Colote muchas gracias por tu respuesta, eso era justo lo que yo necesitaba, ya con eso tengo hecho el 50% de mi aplicacion

nuevamente mil gracias!!!!!!!!!!!!!
Atención: Estás leyendo un tema que no tiene actividad desde hace más de 6 MESES, te recomendamos abrir un Nuevo tema en lugar de responder al actual.
Respuesta




La zona horaria es GMT -6. Ahora son las 13:08.