[PHP + JS] Error simple. Pero yo no lo encuentro.

Iniciado por Ori-chan, 27 Febrero 2013, 16:59 PM

0 Miembros y 2 Visitantes están viendo este tema.

Ori-chan

Estaba practicando con PHP + JS e intenté hacer esto... pero no funciona.



Código (lenguage) [Seleccionar]

<head>
<title>Velocidad</title>
<head/>

<script type="text/javascript">
fuction velocidad () {
var espacio = <?php echo $_REQUEST['espacio']; ?>
var tiempo = <?php echo $_REQUEST['tiempo']; ?>
var velocidad = espacio / tiempo;
"respuesta:" + velocidad;
document.write ("respuesta:" + velocidad);
}
</script>

<body>
<form action="#" method="GET">
Tiempo: <input type="text" name="tiempo" size="8" maxlength="30">
Espacio: <input type="text" name="espacio" size="8" maxlength="30">
<input type="button" onclick="velocidad()" value="confirmar">
</form>

</body>





Un saludo, gracias por leer y espero tu respuesta!! :D


it3r

php solo se ejecuta en el servidor.El problema es que tienes el action con #, entonces tu php no se recarga y por tanto no va a poder ejecutar el codigo php que tienes en la parte de espacio y tiempo.

Tienes 2 posibles soluciones.

-Recargar la pagina.
-Hacerlo solo javascript.

Para recargar la pagina debes cambiar el action en el form.
Para hacerlo con javascript, debes cambiar el codigo php por javascript, es decir seleccionar los inputs con javascript (lo puedes hacer usando id)

Saludos.

1mpuls0

En realida no sé que intentas hacer xD pero podrías hacerlo así con js

Código (html4strict) [Seleccionar]

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Documento sin título</title>
<script language="javascript">
function velocidad() {
var tiempo = document.getElementById('tiempo').value;
var espacio = document.getElementById('espacio').value;
var velocidad = espacio / tiempo;
document.getElementById('resultado').innerHTML=velocidad;
}
</script>
</head>

<body>
<!--<form action="#" method="GET">-->
Tiempo: <input type="text" name="tiempo" id="tiempo" size="8" maxlength="30">
Espacio: <input type="text" name="espacio" id="espacio" size="8" maxlength="30">
<input type="button" onclick="velocidad()" value="confirmar">
<!--</form>-->
<div id="resultado"></div>
</body>
</html>



o así como mas o menos lo necesitas.

Código (php) [Seleccionar]

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Documento sin título</title>
<?PHP
if(isset($_POST['confirmar'])) {
if(!empty($_POST["tiempo"]) && !empty($_POST["espacio"])) {
?>
<script language="javascript">
                var tiempo = <?php echo $_POST['tiempo']; ?>;
var espacio = <?php echo $_POST['espacio']; ?>;
var velocidad = espacio / tiempo;
                document.write ("respuesta: " + velocidad);
                </script>
            <?php
}
}  
?>


</head>

<body>

<form action="#" method="POST">
Tiempo: <input type="text" name="tiempo" id="tiempo" size="8" maxlength="30">
Espacio: <input type="text" name="espacio" id="espacio" size="8" maxlength="30">
<input type="submit" name="confirmar" id="confirmar" value="confirmar" />
</form>

</body>
</html>


Exactamente como lo necesitas no se puede :P ya mencionaron una razón xD
No puedes enviar el resultado a la misma página y despues a la función.

Tienes que saber como funciona los submit, button, get, post, action, onclick etc y saber como combinarlos de manera correcta.

Saludos.
abc

Ori-chan

Muchas gracias a los dos. Supongo que aun tengo que practicar mucho.


1mpuls0

Aunque no es muy aconsejable hacerlo de la segunda forma.
Si observas el GeSHi no detecta donde termina js xD y es que es un lio cuando mezclas js con php.

Saludos.
abc

Ori-chan

Entonces para que sirve PHP? Si se puede hacer con JS lo mismo


#!drvy

CitarEntonces para que sirve PHP? Si se puede hacer con JS lo mismo

PHP -> Servidor
JS -> Cliente.

Con el JS puedes hacer esto.... pero si lo quieres guardar que ?

javascript no puede manejar bases de datos... no puede acceder a archivos del servidor... es muy limitado al mismo dominio (la política del mismo origen..) y muchas otras cosas...

Claro que existe JS Server (Node.js por ejemplo).. pero esa es otra historia.


Saludos

1mpuls0

Estrictamente no es lo msimo, depende de lo que quieras hacer, hacia donde envias tu información, donde quieres mostrar tu resultado.
En pocas palabras ambos se complementan.

JS lado del cliente (validaciones, verificaciones, "animaciones")
PHP lado del servidor (programación dinámica, cálculos, base de datos)

Con ambos puedes crear algunas funciones "iguales" (lo único que cambia es la sintaxis)

Saludos.
abc

dank_

Sólo comentar que esa combinación de PHP con javascript que intentabas hacer es extremadamente vulnerable a XSS.