Ver Mensaje Individual
  #1 (permalink)  
Antiguo 20/03/2015, 08:58
Avatar de oshho
oshho
 
Fecha de Ingreso: marzo-2015
Mensajes: 40
Antigüedad: 9 años, 9 meses
Puntos: 0
Pregunta Retorno de valor Onchange para ser usado como parametro

Buenas a todos, es primera vez que ingreso a este foro y es increíble la cantidad de contenido que hay aquí, y la ayuda que brindan los usuarios es muy buena, es por ello que en esta ocasión requiero de su ayuda hahaha. Bueno directo al grano, resulta que estoy haciendo una aplicación web con JSP, dentro de esta aplicación tengo 2 combobox, 1 combobox carga una lista desde una base de datos, y el segundo combobox debería hacer lo mismo, pero basado en la selección del primer combobox. (Un ejemplo muy común de esto es clasico par de combos "País" y "Ciudad" en el que el segundo solo cargaría las ciudades del país seleccionado)

Bueno a continuación le dejo le codigo de mi JSP, en el cual yo se que me falta hacer algo en la función cargarCTN(), pero bueno hace 10 minutos que comencé a usar Javascript por primera vez en mi vida, por lo que no entiendo mucho.

Código Java:
Ver original
  1. <html>
  2.     <head>
  3.         <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
  4.         <!--Funcion javascript para la carga del combobox/drop-down list de transacciones -->
  5.         <script type="text/javascript">
  6.             function cargarCTN()
  7.             {
  8.                 //toma la ID de la aplicación seleccionada del combo cmbApplicationName
  9.                 var seleccion = document.getElementById('cmbAN');
  10.             }
  11.         </script>
  12.         <title>JSP Page</title>
  13.     </head>
  14.  
  15. <body>
  16.         <form name="frmEliminar" method="POST">
  17.             <table>
  18.                 <tbody>
  19.                     <tr>
  20.                         <td>Nombre de Aplicación</td>
  21.                         <td><select  style="width: 317px" id="cmbAN" name="cmbApplicationName" onchange="cargarCTN()" >
  22.                                 <option>--Seleccione--</option>
  23.                         <!-- Carga el combobox/drop-down list con las posibles aplicaciones -->
  24.                                 <%for(Application appl: new dao.ApplicationDao().listarAplicaciones()){%>
  25.                                 <option value="<%= appl.getIdApplication() %>"><%= appl.getNameApplication()%></option>
  26.                                 <% }%>
  27.                             </select></td>
  28.                     </tr>
  29.                     <tr>
  30.                         <td>Nombre de Transacción</td>
  31.                         <td><select  id="cmbTN" name="cmbTransactionName">
  32.                                 <option>--Seleccione--</option>
  33.                                 <%for(Transaction tran: new dao.TransactionDao().listarTransacciones("AQUI VA LA ID OBTENIDA DEL SELECT ANTERIOR (cmbApplicationName)")) {%>
  34.                                 <option value="<%= tran.getIdTransaction() %>"><%= tran.getNameTransaction()%></option>
  35.                                 <%}%>
  36.                             </select></td>
  37.                     </tr>
  38.                     <tr>
  39.                         <td>Desde: </td>
  40.                         <td><input name="dtpFechaInicio" id="datetimepicker1" type="text" ></td>
  41.                     </tr>
  42.                     <tr>
  43.                         <td>Hasta: </td>
  44.                         <td><input name="dtpFechaFin" id="datetimepicker2" type="text" ></td>
  45.                     </tr>
  46.                 </tbody>
  47.             </table>
  48.             <br>
  49.             <input type="submit" value="BUSCAR" name="btnBuscar" /> <input type="submit" value="ELIMINAR" name="btnEliminar" />
  50.         </form>
  51.     </body>
  52.          
  53.     <!-- Jquery para Datetimepicker-->
  54.         <link rel="stylesheet" type="text/css" href="jsdtp/jquery.datetimepicker.css">
  55.         <script src="jsdtp/jquery.js"></script>
  56.         <script src="jsdtp/jquery.datetimepicker.js"></script>
  57.         <script>jQuery('#datetimepicker1').datetimepicker();</script>
  58.         <script>jQuery('#datetimepicker2').datetimepicker();</script>
  59. </html>

Bueno, prácticamente lo que quiero hacer es que al seleccionar una opción del cmbApplicationName y que a través del onchange este devuelva la ID para ser utilizada como parámetro de entrada para cargar el cmbTransactionName, a continuación les dejo la query que tengo en una clase Java para obtener la lista del cmbTransactionName.

Código Java:
Ver original
  1. /** Crea y devuelve una lista (ArrayList) con la ID y nombre
  2.      * de las transacciones a base de la ID de una aplicación. */
  3.     public static ArrayList<Transaction> listarTransacciones(int appID){
  4.         ArrayList<Transaction> trans = new ArrayList<Transaction>();
  5.         Connection conexion = Conexion.getConexion();
  6.         try {
  7.             String query = " USE ddbs "
  8.                     + "SELECT TransactionID, TransactionName "
  9.                     + "FROM Transactions, Applications "
  10.                     + "WHERE Applications.ApplicationID = ?";
  11.             PreparedStatement listar = conexion.prepareStatement(query);
  12.             listar.setInt(1, appID);
  13.             ResultSet rs = listar.executeQuery();
  14.             while(rs.next()){
  15.                 Transaction transaccion = new Transaction();
  16.                 transaccion.setIdTransaction(rs.getInt("TransactionID"));
  17.                 transaccion.setNameTransaction(rs.getString("TransactionName"));
  18.                 trans.add(transaccion);
  19.                
  20.             }
  21.            
  22.        } catch (SQLException ex) {
  23.             out.println("<!DOCTYPE html>");
  24.             out.println("<html>");
  25.             out.println("<head>");
  26.             out.println("<title>Error Exception</title>");            
  27.             out.println("</head>");
  28.             out.println("<body>");
  29.             out.println("<h1>SQLException "+ ex +"</h1>");
  30.             out.println("</body>");
  31.             out.println("</html>");
  32.         } catch (Exception ex) {
  33.             out.println("<!DOCTYPE html>");
  34.             out.println("<html>");
  35.             out.println("<head>");
  36.             out.println("<title>Error Exception</title>");            
  37.             out.println("</head>");
  38.             out.println("<body>");
  39.             out.println("<h1>Exception "+ ex +"</h1>");
  40.             out.println("</body>");
  41.             out.println("</html>");
  42.         }
  43.         return trans;
  44.     }

Bueno, espero que puedan ayudarme haha, por si a alguno no le quedo claro les dejo un dibujito que demuestra lo que quiero hacer (Suponiendo que es posible hacerlo)

Muchas gracias ^^