Foros del Web » Programando para Internet » Javascript »

[SOLUCIONADO] Problema al Sumar

Estas en el tema de Problema al Sumar en el foro de Javascript en Foros del Web. Hola Comunidad. lo que pasa es que intento sumar varios campos de un input con este script Código HTML: <script language= "javascript" > function suma(){ ...
  #1 (permalink)  
Antiguo 07/02/2013, 17:58
Avatar de tesla07  
Fecha de Ingreso: enero-2013
Mensajes: 42
Antigüedad: 11 años, 2 meses
Puntos: 0
Exclamación Problema al Sumar

Hola Comunidad.
lo que pasa es que intento sumar varios campos de un input con este script

Código HTML:
<script language="javascript">
function suma(){
resultado = parseInt(val1.value) + parseInt(val2.value) + parseInt(val3.value);
alert(resultado)
}
</script> 
pero lo que pasa es que los valore vienen de un formulario y hay valores que van a quedar sin ningun valor asi que me muestra error

quisiera saber como hacer para que me muestre el resultado asi varios campos esten vacios.

de antemano Gracias
__________________
Nuestros sentidos nos permiten percibir sólo una pequeña porción del mundo exterior.
  #2 (permalink)  
Antiguo 07/02/2013, 19:53
Avatar de ipraetoriux  
Fecha de Ingreso: abril-2010
Ubicación: ipraetoriux.com
Mensajes: 1.125
Antigüedad: 14 años
Puntos: 155
Respuesta: Problema al Sumar

...el problema que tienes es que cuando recibes un valor vació e intentas transformarlo en entero con el parseInt, obtendrás un valor NaN, o sea un Not a Number, y eso te dará un error en la operación que quieres efectuar. Para solucionarlo podes verificar con el método isNaN() cada valor..te doy un ejemplo...

una forma fácil sin que te compliques de resolverlo seria asi...

Código Javascript:
Ver original
  1. function sumar(){
  2.   var numeros = [];
  3.   var suma = 0;
  4.  
  5.   var a1 = parseInt(document.getElementById('valor1').value);
  6.   numeros.push(a1);
  7.   var a2 = parseInt(document.getElementById('valor2').value);
  8.    numeros.push(a2);
  9.   var a3 = parseInt(document.getElementById('valor3').value);
  10.    numeros.push(a3);
  11.  
  12.   for(var i=0; i<numeros.length; i++){
  13.     if(isNaN(numeros[i])){
  14.       numeros[i] = 0;
  15.     }
  16.     suma+=numeros[i];
  17.   }
  18.  
  19.   console.log(suma);
  20. }

..por supuesto podes optimizar esta función, podes recorrer todo el formulario e ir agregando cada valor en el array, transformalo en int verificar si es Nan para luego sumarlo
  #3 (permalink)  
Antiguo 10/02/2013, 12:15
Avatar de tesla07  
Fecha de Ingreso: enero-2013
Mensajes: 42
Antigüedad: 11 años, 2 meses
Puntos: 0
Respuesta: Problema al Sumar

Cita:
Iniciado por ipraetoriux Ver Mensaje
...el problema que tienes es que cuando recibes un valor vació e intentas transformarlo en entero con el parseInt, obtendrás un valor NaN, o sea un Not a Number, y eso te dará un error en la operación que quieres efectuar. Para solucionarlo podes verificar con el método isNaN() cada valor..te doy un ejemplo...

una forma fácil sin que te compliques de resolverlo seria asi...

Código Javascript:
Ver original
  1. function sumar(){
  2.   var numeros = [];
  3.   var suma = 0;
  4.  
  5.   var a1 = parseInt(document.getElementById('valor1').value);
  6.   numeros.push(a1);
  7.   var a2 = parseInt(document.getElementById('valor2').value);
  8.    numeros.push(a2);
  9.   var a3 = parseInt(document.getElementById('valor3').value);
  10.    numeros.push(a3);
  11.  
  12.   for(var i=0; i<numeros.length; i++){
  13.     if(isNaN(numeros[i])){
  14.       numeros[i] = 0;
  15.     }
  16.     suma+=numeros[i];
  17.   }
  18.  
  19.   console.log(suma);
  20. }

..por supuesto podes optimizar esta función, podes recorrer todo el formulario e ir agregando cada valor en el array, transformalo en int verificar si es Nan para luego sumarlo
Oye Pero Lo Que No Veo es de como muestro el resultado
__________________
Nuestros sentidos nos permiten percibir sólo una pequeña porción del mundo exterior.
  #4 (permalink)  
Antiguo 10/02/2013, 14:21
Avatar de ipraetoriux  
Fecha de Ingreso: abril-2010
Ubicación: ipraetoriux.com
Mensajes: 1.125
Antigüedad: 14 años
Puntos: 155
Respuesta: Problema al Sumar

console.log(suma);
  #5 (permalink)  
Antiguo 10/02/2013, 18:40
Avatar de ipraetoriux  
Fecha de Ingreso: abril-2010
Ubicación: ipraetoriux.com
Mensajes: 1.125
Antigüedad: 14 años
Puntos: 155
Respuesta: Problema al Sumar

...oiga mi amigo, el console.log() en una salida por consola para verificar el resultado, si deseas mostrarlo en la web, no te sirve, tienes que usar algun alert() o incluir el resultado dentro de algun elemento (etiqueta)..saludos

Etiquetas: javascript+html, javascript+php, javascript-funciones, operaciones, suma
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 00:16.