Foros del Web » Programando para Internet » PHP »

¡ problemón !

Estas en el tema de ¡ problemón ! en el foro de PHP en Foros del Web. Tengo una pagina php que muestra noticias de 5 en 5 pero al darle a la segunda pagina me cambia la barra de direcciones: De: ...
  #1 (permalink)  
Antiguo 26/05/2004, 09:18
Avatar de TOTE  
Fecha de Ingreso: mayo-2004
Ubicación: Murcia
Mensajes: 71
Antigüedad: 19 años, 11 meses
Puntos: 0
¡ problemón !

Tengo una pagina php que muestra noticias de 5 en 5 pero al darle a la segunda pagina me cambia la barra de direcciones:

De: pagina.php?v_next=0;
A: pagina.php?v_next=5;


pero no modifica la pagina, sigue estando la primera que muestra del 1 al 5.

Yo creo que el problema esta en el link:

echo" | <a href=\"$php_self?v_next=".$v_next."\">".$j."</a>";

j es la varible que va poniendo los numeros de pagina.

Creo que el link falla tambien porque debo de pasarle alguna otra variable que indique donde empezar.

En definitiva, que paginar pagina pero no me enseña más de la primera página.
__________________
No sé si navego o naufrago...
  #2 (permalink)  
Antiguo 26/05/2004, 09:26
Ex Colaborador
 
Fecha de Ingreso: junio-2002
Mensajes: 9.091
Antigüedad: 21 años, 10 meses
Puntos: 16
Hola,

En principio parece que es v_next la que indica el numero de registro que empiza a mostrar. ¿Como lo recoges para pasaar al algoritmo de paginacion?

Saludos.
__________________
Josemi

Aprendiz de mucho, maestro de poco.
  #3 (permalink)  
Antiguo 26/05/2004, 09:32
Avatar de TOTE  
Fecha de Ingreso: mayo-2004
Ubicación: Murcia
Mensajes: 71
Antigüedad: 19 años, 11 meses
Puntos: 0
Mi codigo es el siguiente:


$numero = 5;
if ( $v_next == 0){
$v_next = 0;

$tabla = "rma";
$elcampo = "row2[Empresa]";
$query= "select * from $tabla LIMIT ".$v_next.",".$numero."";
$result= mysql_query($query);

}if ($result != 0)
{
if ($row = mysql_fetch_array($result))
{
echo "<html><body>";
echo "<table border='1' align='left' cellspacing='2' cellpadding='2'>";
echo "<tr><td><b>Resultados</b></td></tr>";
do
{
echo "<tr><td>";
echo $row["Empresa"];echo $row["Fecha"];
echo "<td></tr>";
$v_next++;
}
while($row = mysql_fetch_array($result));

$query2 = "select count(*) num_reg from $tabla ";
$result2=mysql_query($query2);
$row2 = mysql_fetch_array($result2);
$num_reg = $row2["num_reg"];

$num_pag = $num_reg/$numero;
$j = 1;
$v_next = 0;

echo "<tr><td>&nbsp;</td></tr>";
echo "<tr><td>N&uacute;mero de Resultados:<b>$num_reg</b></td></tr>";
echo "<tr><td>&nbsp;</td></tr>";
echo "<tr><td>";
for ($i=0; $i<$num_pag; $i++)
{
echo " | <a href=\"$PHP_SELF?v_next=".$v_next."\">".$j."</a>";
$j++;
$v_next =$v_next + $numero;
}
echo "</td></tr>";
echo "</table>";

mysql_free_result($result);
} }

Muchas Gracias.
__________________
No sé si navego o naufrago...
  #4 (permalink)  
Antiguo 26/05/2004, 10:06
Ex Colaborador
 
Fecha de Ingreso: junio-2002
Mensajes: 9.091
Antigüedad: 21 años, 10 meses
Puntos: 16
¿Valor de la directiva register_globals en el php.ini?

De todas formas, usa:
Código PHP:
 if ( !isset($_GET['v_next'])){
  
$v_next 0;
 } else {
   
$v_next=$_GET['v_next'];
 } 
si tu version es superior a PHP4.1.

Y quita el } de delante del if ($result != 0).

Y verifica que te genera el numero correcto de paginas para los valores de 9, 10 y 11 registros.

Saludos.
__________________
Josemi

Aprendiz de mucho, maestro de poco.
  #5 (permalink)  
Antiguo 26/05/2004, 10:42
Avatar de TOTE  
Fecha de Ingreso: mayo-2004
Ubicación: Murcia
Mensajes: 71
Antigüedad: 19 años, 11 meses
Puntos: 0
Muchas Gracias Josemi !!!

Funciona de cine. Espero devolvértelo algún día.
__________________
No sé si navego o naufrago...
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 10:45.