UNIVERSIDAD DON BOSCO FACULTAD DE ESTUDIOS TECNOLÓGICOS COMPUTACIÓN

Tamaño: px
Comenzar la demostración a partir de la página:

Download "UNIVERSIDAD DON BOSCO FACULTAD DE ESTUDIOS TECNOLÓGICOS COMPUTACIÓN"

Transcripción

1 UNIVERSIDAD DON BOSCO FACULTAD DE ESTUDIOS TECNOLÓGICOS COMPUTACIÓN CICLO: 02/2014 Nombre de la Practica: Lugar de Ejecución: Tiempo Estimado: MATERIA: DOCENTES: GUIA DE LABORATORIO #5 Objetos en JavaScript Centro de cómputo 2 horas con 30 minutos Lenguajes Interpretados en el Cliente Ing. Ricardo Ernesto Elías Guandique I. OBJETIVOS Que el estudiante: Tenga claras todas las características de la Programación Orientada a Objetos con JavaScript. Utilice los diversos tipos de objetos incorporados con que cuenta el lenguaje JavaScript. Se familiarice con los objetos del navegador más utilizados en los scripts. II. INTRODUCCION TEORICA Programación Orientada a Objetos en JavaScript La Programación Orientada a Objetos está basada en el concepto de dos entidades distintas, que son: las clases y las instancias. Una clase define las propiedades y métodos, a veces denominados simplemente miembros, que caracterizan a un cierto grupo de objetos. Una clase es una abstracción de ciertos objetos que existen en la realidad e intenta ser un modelo o plano de los objetos que representa, definiendo únicamente las características y el comportamiento que debe tener dicho objeto. La instancia es un objeto concreto creado a partir de las propiedades y métodos definidos en la clase, a veces se prefiere decir que la instancia es un ejemplar concreto del tipo de objeto definido en la clase a partir de la cual se ha creado el objeto. Por ejemplo, Victoria Escobar es una instancia o un ejemplar concreto de la clase empleado, representando a una persona en particular que es o tiene las características y comportamiento de un empleado. Los lenguajes basados en clases, como Java, C++ o C#, exigen que se deba definir primero una clase y a continuación realizar instancias de esta clase para crear un objeto en particular. JavaScript, es más bien un lenguaje basado en prototipos que no requiere hacer esta distinción, simplemente es un lenguaje que tiene objetos predefinidos, a los que se conoce como prototipos y que son, en la práctica, plantillas a partir de las cuales se obtienen propiedades y métodos para los nuevos objetos que se crean. Sin embargo, cada nuevo objeto puede especificar sus propias propiedades y métodos, tanto al ser creado o en tiempo de ejecución. Diferencias entre lenguajes basados en clase en comparación con los basados en prototipos La siguiente tabla resume las diferencias entre los lenguajes basados en clases, como Java o C#, y los basados en prototipos como JavaScript. Basado en Clases (Java) Clase e instancia son entidades distintas. Define una clase con la definción de clase; instancia una clase con los métodos constructores. Crea un único objeto con el operador new. Basado en Prototipos (JavaScript) Todos los objetos son instancias. Define y crea un conjunto de objetos con las funciones constructoras. Igualmente. 1 / 58

2 Construye una jerarquía de objetos utilizando las definiciones de clases par definir subclases de una clase existente. Hereda las propiedades mediante el seguimiento de la cadena de clases. La definción de Clases especifica todas las propiedades de todas las intancias de una clase. No puede añadir propiedades dinámicamente en tiempo de ejecución. Construye una jerarquía de objetos mediante la asignación de un objeto como prototipo asociado con la función constructora. Hereda las propiedades mediante el seguimento de la cadena de prototipos. La función constructora o prototipo puede especificar un conjunto inicial de propiedades. Puede añadir o remover dinámicamente a objetos individuales o a un conjunto entero de objetos. Definición de objeto Los objetos en JavaScript son tipos de datos compuestos, tal y como las matrices o arreglos, que dentro del lenguaje JavaScript son, más bien, objetos. Se dice que son compuestos porque combinan estado (propiedades que almacenan datos) y comportamiento (procedimientos o métodos para operar los datos). Un objeto viene siendo una representación concreta, particular y real de algo. Esta representación determina su identidad, su estado y su comportamiento. Clasificación de objetos en JavaScript Los objetos en JavaScript se pueden subdividir en cuatro grupos: Objetos definidos por el usuario. Son objetos completamente personalizables que puede crear el desarrollador para dar estructura y coherencia a una tarea de programación en particular. Con estos objetos es posible definir propiedades y métodos mediante una sintaxis específica de JavaScript. Las propiedades identifican las características propias del objeto, mientras que los métodos permiten realizar tareas u operaciones con dichas propiedades. Objetos incorporados del lenguaje. Son objetos proporcionados por el propio lenguaje JavaScript, entre los que se incluyen: (1) objetos asociados a tipos de datos primitivos, como los objetos String, Number y Boolean, (2) objetos que permiten la creación de objetos definidos por el usuario, como los objetos Object y Form, (3) objetos utilizados para simplificar tareas frecuentes, como los objetos Date, Math y RegExp. Objetos de navegador. Son objetos que no están especificados como parte del lenguaje JavaScript, pero que son soportados por la mayor parte de navegadores que cumplen con los estándares. Los dos objetos más utilizados que pertenecen a esta categoría son los objetos window y Navigator. El primero permite el control de la ventana del navegador y, el segundo, proporciona información acerca de la configuración del navegador del usuario. Objetos de documento. Son los objetos que forman parte del Modelo de Objetos de Documento (Document Object Model, abreviado como DOM) definido por la W3C. Es a través de estos objetos que JavaScript puede manejar Hojas de Estilo en Cascada y la ejecución de HTML dinámico. El acceso a los objetos de documento es proporcionado por el navegador mediante el uso del objeto document del objeto window. Creación de objetos en JavaScript Existen dos formas de crear objetos en JavaScript: 1. Utilizando la palabra clave new y el nombre del constructor del objeto a crear. Se pueden crear objetos especializados haciendo uso del operador new y a continuación invocar al método constructor del objeto que inicializa las propiedades del objeto. Ejemplo: var carro = new Object(); carro.marca = "Toyota"; carro.modelo = "Corolla"; carro.npasajeros = 5; carro.annio = 2007; carro.placa = " "; carro.nchasis = "JDSXV39Z "; carro.encender = function(numero){ carro.nchasis == numero? start = "on" : start = "off"; Lenguajes Interpretados en el Cliente 2

3 return start; carro.apagar = function(){ start = off; 2. Utilizando sintaxis de literales de objeto. Esta es la forma más fácil de crear objetos en JavaScript, que consiste de una lista de pares nombre_propiedad : valor separados por comas y encerrados entre llaves. Ejemplo: var coord = {x : 0, y : 0; var circle = {x : coord.x, y : coord.y, r : 2.5; Esta forma de construir objetos en JavaScript es generalizable a todos los tipos de datos del lenguaje. Veamos esto demostrado con dos tipos de objetos como String y Array. Utilizando la palabra clave new y el respectivo método constructor: var nombre = new String(); var paises = new Array("El Salvador","Guatemala","Honduras"); Utilizando sintaxis declarativa conocida como sintaxis de literales de tipos de datos: var nombre = ""; var paises = ["El Salvador","Guatemala","Honduras"]; Objetos del lenguaje Estos son el conjunto de objetos que vienen incorporados por el lenguaje. Entre los principales tenemos los objetos Array, Function, Date, String, Math, Boolean, Number. 1. Objeto Array Este objeto se abordó en guías pasadas, por lo que trataremos únicamente su declaración, propiedades y métodos. La forma de declarar un objeto Array es haciendo uso del constructor Array(). Si se pasan argumentos al constructor, se interpreta que estos serán los elementos del arreglo. La excepción se da cuando se le pasa al constructor un solo valor numérico, en cuyo caso se entiende que se le proporciona al arreglo un tamaño, que podremos acceder mediante la propiedad length. Los siguientes son ejemplos de declaración de objetos Array: //Crea un arreglo vacío (sin elementos definidos) y crea una referencia //a él en la variable arreglo1 var arreglo1 = new Array(); //Crea un arreglo con tres elementos var arreglo2 = new Array("rojo", "verde", "azul"); //Crea un arreglo cuya propiedad length tiene el valor de 5 var arreglo3 = new Array(5); Propiedades del objeto Array length Como su nombre indica esta propiedad nos devuelve la longitud del array, es decir, el número de elementos que puede almacenar. Su uso es muy simple: var lista = new Array(50); tamagno = lista.length; /*tamagno almacenaría el valor 50 */ prototype Esta es una propiedad muy potente en el sentido que nos permite agregar al objeto Array las propiedades y métodos que queramos. Array.protoype.descriptor = null; Lenguajes Interpretados en el Cliente 3

4 dias = new Array ('lunes', 'Martes', 'Miercoles', 'Jueves', 'Viernes'); dias.descriptor = "Dias laborables de la semana"; En este ejemplo hemos creado una nueva propiedad para el objeto Array, la propiedad descriptor que podría utilizarse para darle un título a la matriz. Métodos del objeto Array Para ver estos métodos consulte la guía sobre arreglos realizada recientemente. Entre dichos métodos se encuentran: concat(), join(), reverse(), sort(), pop(), push(), etc. 2. Objeto Function Las funciones también son consideradas como objetos por JavaScript. Aunque normalmente no estamos acostumbrados a definirlas de esta forma, JavaScript proporciona una forma de definir funciones en donde explícitamente se declaran como objetos. Para ello se utiliza el operador new y el constructor Function, tal y como se muestra a continuación: sumar = new Function( a, b, return a + b ); La llamada a la function se realize de la misma forma que conocemos. Puede ver el siguiente ejemplo de llamada: document.write(sumar(90, 100)); Métodos de Function Los métodos de Function son todos los heredados del objeto Object, que veremos más adelante. Propiedades del objeto Function Básicamente se tienen tres propiedades que se pueden usar con el objeto Function y son: arguments Se trata de un array que contiene los argumentos pasados a la función. Esta propiedad permite el uso de funciones con un número variable de argumentos. caller Contiene una referencia a la función que llamó a la actual. constructor Heredada de la clase Object. 3. Objeto String El objeto String se usa para manipular cadenas de caracteres. En JavaScript todo texto encerrado entre comillas, dobles o simples, se interpreta como una cadena, así '45' no es el número cuarenta y cinco sino la cadena formada por los caracteres 4 y 5. Este objeto contiene una gran cantidad de métodos para el manejo y el análisis de cadenas, la extracción de subcadenas e incluso para la conversión de cadenas a texto de marcado HTML. Como en los anteriores objetos se utiliza el operador new y el constructor String(), como se muestra a continuación: var cadena = new String(); También se puede pasar un argumentos al constructor, que será su valor inicial, como se muestra en este otro ejemplo: var cadena = new String( No me importa. ); Propiedades del objeto String length Valor numérico que nos indica la longitud en caracteres de la cadena dada. prototype Lenguajes Interpretados en el Cliente 4

5 Nos permite asignar nuevas propiedades al objeto String. Métodos del objeto String anchor(name) Crea un enlace (o ancla) a partir de un objeto String con el atributo name igual a la cadena que se le pasa como argumento al método. Vea el siguiente ejemplo: var refer "referencia1"; var ancla1 = refer.anchor("anclaje1"); Después de ejecutadas las instrucciones anteriores el valor de ancla será: <a name= anclaje1 >referencia1</a> La sintaxis de este método permite usar una constante String en lugar del nombre de un objeto String. El ejemplo anterior podría haber escrito como: var ancla = "referencia1".anchor("anclaje1"); charat(position) Este método aplicado a una cadena devuelve el carácter que se encuentra en la posición dada por el atributo position teniendo en cuenta que el índice del primer carácter a la izquierda de la cadena es 0 y el último es una unidad menor que longitud de la cadena. Si el valor del atributo no es válido (igual o mayor que la longitud de la cadena o negativo) el método devuelve el valor undefined. Por ejemplo, el siguiente código devuelve el carácter en la tercera posición de la cadena nombre: var nombre = "abcdefghij"; var car3 = nombre.charat(2); Devolverá "c", que es el tercer carácter por la izquierda (índice igual a 2). 4. Manejo de fechas El objeto Date contiene un valor que representa fecha y hora de un instante dado. Para crear una instancia de este objeto usamos alguna de las siguientes sintaxis: var fecha = new Date() var fecha = new date(número) var fecha = new date(cadena) var fecha = new date(año, mes, día[, hora[, minutos[,seg[,ms]]]]) Los argumentos encerrados entre corchetes son opcionales. En la primera forma la variable fecha contendrá la fecha del día actual. La segunda opción almacena en fecha la fecha dada por el argumento como el número de milisegundos transcurridos desde la media noche del 1 de Enero de El tercer tipo se usa cuando la fecha se pasa en forma de cadena. Por último la fecha puede crearse pasándole como argumento los números de año, mes, día, hora y opcionalmente, hora, minuto, segundo y milisegundo. Los años posteriores a 1970 puede escribirse con dos dígitos, pero es aconsejable usar siempre cuatro dígitos por aquello de los efectos var hoy = new date() /*fecha del día en hoy */ var evento = new Date("November "); var otro = new Date("10 Nov 1990"); var otro = new Date("10/02/2000"); //Oct, 2, 2000 var instante = new Date(1990, 11, 10, 20,00); Estas son las posibles formas de declarar objetos de tipo fecha. Las dos últimas almacenan el mismo día, pero en la última además se guarda la hora. Lenguajes Interpretados en el Cliente 5

6 Donde se usen cadenas para indicar una fecha podemos añadir al final las siglas GMT (o UTC) para indicar que la hora se refiere a hora del meridiano Greenwich, si no se toma como hora local, o sea, según la zona horaria configurada en el ordenador donde se ejecute el script. Métodos GetDate() Nos devuelve el día del mes del objeto fecha al que se aplica. Este método controla por supuesto el número de días de cada mes y contempla el caso de años bisiestos, incluida la excepción del En el siguiente ejemplo se presenta en pantalla Hoy es día 2, suponiendo que la fecha del sistema es Primero creamos la variable fecha instanciada como un objeto Date() para a continuación escribir directamente el valor de getdate() aplicado a fecha var fecha = new Date(); document.write("hoy es día: "+fecha.getdate()); setfullyear() Nos permite cambiar el año del objeto fecha por el valor pasado como argumento, un número de dos dígitos que se interpreta como decenas dentro del siglo, o sea, que para poner el año 1995 se debe pasar 95. El ejemplo pone precisamente este valor en el campo año de la variable fecha. var fecha = new Date(); fecha.setyear(95) document.write(fecha.tostring()); Ojo si pasamos el valor 00 en el argumento el año obtenido es el 1900 (uno de los efectos 2000), por esto es recomendable usar la función setfullyear(agno). setdate() Nos permite cambiar el día del mes del objeto fecha al que se aplica para poner el valor que se pasado en el argumento diames. Este método controla por supuesto el número de días de cada mes y contempla el caso de años bisiestos, incluida la excepción del 2000, de forma que si pasamos como argumento 31 y el mes es de 30 días la función corrige la fecha completa pasándola al día 1 del mes siguiente. Esto lo vemos en el ejemplo que sigue: creamos una variable como un objeto Date con el último día de Septiembre (mes de 30 días) e intentamos poner el día a 31, luego comprobamos la fecha almacenada: var fecha = new Date("1 Sep 2008"); fecha.setdate(31); document.write("hoy es día: " + fecha.tostring()); Como puede verse, si se prueba el ejemplo la fecha es corregida y pasa a 1 de Octubre. Objetos del navegador. Los objetos del navegador se encuentran en el nivel más alto de la jerarquía de objetos que define JavaScript. Estos son window, frame, location, history, y navigator. El objeto más alto en la jerarquía de objetos que define JavaScript es window. El resto de objetos (excepto el objeto navigator) se ubican siempre dentro de una ventana. Los métodos y propiedades de los objetos window y navigator pueden utilizarse sin necesidad de declarar variables. Ejemplo: //Mostrar la hora segundo a segundo function hourstatus(){ var mifecha = new Date(); window.status = formato(mifecha.gethours()) + ":" + formato(mifecha.getminutes()) + ":" + formato(mifecha.getseconds()); //Llamando a la función segundo a segundo Lenguajes Interpretados en el Cliente 6

7 settimeout("hourstatus()", 1000); //Función para formatear las partes de la hora function formato(valor){ if(valor<10) valor = "0" + valor; return valor; Objetos de documento Los objetos del documento se encuentran en el segundo nivel de la jerarquía de objetos que define JavaScript. Estos son document, link, anchor e image. Estos objetos permiten a JavaScript, entre otras cosas, el manejo de Hojas de Estilo en Cascada y la ejecución de HTML dinámico (DHTML). El acceso a los objetos del documento es proporcionado por el navegador mediante el uso de la propiedad document del objeto window. Ejemplo: //Función que obtiene el texto seleccionado function gettextselected(){ var seltext = ""; //Internet Explorer if(document.selection){ seltext = document.selection.createrange().text; //Otros navegadores (Chrome, Firefox, Opera, etc.) if(window.getselection){ seltext = window.getselection(); if(document.getselection){ seltext = document.getselection(); //Asignar el texto seleccionado a un elemento P document.getelementbyid("paragraph").innerhtml = "<p>texto seleccionado: " + seltext + "</p>"; Estas últimas dos categorías de objetos se estudiarán con más detalle en próximas guías de práctica. III. MATERIALES Y EQUIPO Para la realización de la guía de práctica se requerirá lo siguiente: No. Requerimiento Cantidad 1 Guía de práctica #5: Objetos en JavaScript 1 2 Computadora con Sublime Text PHP Designer 2007 y navegadores instalados 1 3 Memoria USB o disco flexible 1 IV. PROCEDIMIENTO Para los ejemplos del procedimiento de esta guía se ha utilizado el enfoque de desarrollo con JavaScript no invasivo. Esto significa que el manejo de eventos no se realizará en casi ningún caso con atributos manejadores de eventos dentro del código HTML. El manejo de eventos se hace con el modelo de eventos estándar, conocido como modelo de eventos Nivel 2 del DOM, que dicho sea de paso, es mucho más eficiente y propicia la completa separación de la funcionalidad del documento web de su estructura, algo muy similar a la separación de la apariencia de la estructura del documento lograda con el correcto manejo de las hojas de estilo en cascada. Ejemplo #1: El ejemplo solicita dos valores numéricos (pueden ser con punto flotante) para calcular, presionando los botones respectivos, el perímetro y el área de un rectángulo con esas dimensiones. Se Lenguajes Interpretados en el Cliente 7

8 utilizan campos de formulario de tipo number, incorporados en HTML5 y se establecen valores mínimo, máximo y el desplazamiento para manejar los valores ingresados con el control que algunos navegadores modernos incorporan. También es factible ingresar los valores directamente. Guión 1: rectangulo.html <!DOCTYPE html> <html lang="es"> <head> <title>áreas de rectángulos</title> <meta charset="utf-8" /> <link rel="stylesheet" href="css/slick.css" /> <link rel="stylesheet" href="css/demo.css" /> <script type="text/javascript" src="js/calculo.js"></script> </head> <body> <section id="slick"> <!-- Área de formulario --> <div class="contact-form"> <!-- Título --> <div class="title">cálculo de área y perímetro</div> <!-- Texto indicativo --> <p class="intro">ingrese los siguientes datos</p> <!-- Formulario --> <div class="w-100"> <!-- Campos de formulario --> <form name="frmrectangulo" id="frmrectangulo" action="javascript:void(0);"> <!-- Campo para la base --> <div class="field"> <input type="number" name="base" id="txtbase" min="0" max="1000" step=".1" placeholder="(base)"required /> <span class="entypo-base icon"></span> <span class="slick-tip left">ingrese la base:</span> </div> <!-- Campo para la altura --> <div class="field"> <input type="number" name="altura" id="txtaltura" min="0" max="1000" step=".1" placeholder="(altura)" required /> <span class="entypo-altura icon"></span> <span class="slick-tip left">ingrese la altura:</span> </div> <!-- Botones para hacer los cálculos --> <input type="submit" value="area" class="send" name="btnarea" id="area" /> <input type="submit" value="perimetro" class="send" name="btnperimetro" id="perimetro" /> </form> <!-- Fin de campos de formulario --> </div> </div> <!-- Final del área del formulario --> </section> </body> </html> Guión 2: calculo.js //Registrar evento click del ratón al presionar botones de envío function iniciar(){ var btnarea = document.getelementbyid("area"); var btnperim = document.getelementbyid("perimetro"); if(btnarea.addeventlistener){ btnarea.addeventlistener("click", calculararea, false); else{ btnarea.attachevent("onclick", calculararea); Lenguajes Interpretados en el Cliente 8

9 if(btnperim.addeventlistener){ btnperim.addeventlistener("click", calcularperimetro, false); else{ btnperim.attachevent("onclick", calcularperimetro); function calculararea(){ var rect = new rectangulo(document.frmrectangulo.txtbase.value, document.frmrectangulo.txtaltura.value); rect.mostrar(rect.carea(), " área"); return false; function calcularperimetro(){ var peri = new rectangulo(document.frmrectangulo.txtbase.value, document.frmrectangulo.txtaltura.value); peri.mostrar(peri.cperimetro(), 'perímetro'); return false; //Creando una clase rectángulo function rectangulo(base, altura){ //Propiedades de la clase this.base = parsefloat(base); this.altura = parsefloat(altura); //Métodos de la clase this.carea = new Function("return this.base * this.altura"); this.cperimetro = new Function("return 2*this.base + 2*this.altura"); this.mostrar = new Function("valor","tipoc","alert('El ' + tipoc + ' es: ' + valor)"); //Asociando función que manejará el evento load al cargar la página if(window.addeventlistener){ window.addeventlistener("load", iniciar, false); else{ window.attachevent("onload", iniciar); Guión 3: slick.css /* ===================================== 1. FUENTES IMPORTADAS DE GOOGLE FONTS ===================================== url( /* Lobster font for headings url( /* Lato font for the content */ /* Entypo pictograms by Daniel Bruce { font-family: 'entypo'; font-style: normal; font-weight: normal; src: url('../fonts/entypo.eot'); src: url('../fonts/entypo.eot?#iefix') format('eot'), url('../fonts/entypo.woff') format('woff'), url('../fonts/entypo.ttf') format('truetype'), url('../fonts/entypo.svg#entypo') format('svg'); Lenguajes Interpretados en el Cliente 9

10 /* =================== 2. RESETEAR ESTILOS =================== */ body { background:url("../img/bg.jpg") 0 0 repeat; height:100%; margin:0; padding:0; width:100%; #slick * { margin: 0; padding: 0; border: 0; outline: 0; font-weight: normal; font-style: normal; font-size: 100%; font-family: 'Lato', Arial, Helvetica, sans-serif; vertical-align: baseline; line-height: normal; -moz-box-sizing: border-box; -webkit-box-sizing: border-box; box-sizing: border-box; #slick label { cursor: pointer; #slick input[type="radio"], #slick input[type="checkbox"] { display: none; visibility: hidden; opacity: 0; /* Colocar iconos para los campos typo number */ #slick.entypo-base:before{ content:"\0394"; #slick.entypo-altura:before{ content:"\2207"; #slick a { text-decoration: none; #slick { margin: 40px auto; position: relative; /* Ajustar este valor para cambiar ancho del formulario */ width: 480px; /* ====================== 3. Estilos principales ====================== */ #slick.contact-form { background: #fff; Lenguajes Interpretados en el Cliente 10

11 position: relative; width: 100%; height: auto; float: left; padding: 40px; -webkit-box-shadow: 0 0 8px 0 rgba(0,0,0,0.7); -moz-box-shadow: 0 0 8px 0 rgba(0,0,0,0.7); box-shadow: 0 0 8px 0 rgba(0,0,0,0.7); #slick.w-100, #slick.w-47, #slick.w-30 { float: left; display: inline-block; position: relative; #slick.w-100 { width: 100%; #slick.w-47 { width: 47%; #slick.w-30 { width: 30%; #slick.mr-5 { margin-right: 5%; #slick.mr-6 { margin-right: 6%; #slick.mt-5 { margin-top: 5px; #slick.mt-10 { margin-top: 10px; #slick.mt-20 { margin-top: 20px; #slick.clrfx { clear: both; display: block; width: 100%; float: left; /* ===================== 4. Elementos de texto ===================== */ /***** Encabezado *****/ #slick.title { Lenguajes Interpretados en el Cliente 11

12 font-family: 'Lobster', cursive; font-weight: normal; font-size: 32px; color: #333; line-height: normal; display: inline-block; float: left; /***** Párrafos *****/ #slick p.intro { font-size: 12px; line-height: 16px; display: block; color: #bbb; margin: 20px 0; float: left; clear: both; width: 100%; #slick p.intro b { color: #FF2424; #slick p.tick-text { font-size: 10px; color: #999; display: inline-block; float: left; margin: 8px px; /***** Ayudas textuales *****/ #slick span.slick-tip { width: auto; height: auto; white-space: nowrap; padding: 10px; font-size: 10px; text-align: center; color: #fff; background: #333; position: absolute; opacity: 0; visibility: hidden; z-index: -1; #slick span.slick-tip.right { right: -30px; bottom: 36px; background: #fff; color: #222; #slick span.slick-tip.left { left: 20px; top: -44px; #slick span.slick-tip:before { content: ""; Lenguajes Interpretados en el Cliente 12

13 position: absolute; bottom: -6px; width: 0; height: 0; border-left: 10px solid transparent; border-right: 10px solid transparent; border-top: 6px solid rgba(51,51,51,1); #slick span.slick-tip.right:before { right: 30px; margin-left: -10px; #slick span.slick-tip.right:before { border-top: 6px solid rgba(255,255,255,1); #slick span.slick-tip.left:before { left: 20px; margin-right: -10px; #slick input:focus ~.slick-tip, #slick select:focus ~.slick-tip, #slick textarea:focus ~.slick-tip, #slick.sb a:hover span.slick-tip { opacity: 1; visibility: visible; z-index: 9999; #slick input:required:valid ~.slick-tip, #slick textarea:required:valid ~.slick-tip { opacity: 0; visibility: hidden; z-index: -1; /* ================== 5. ELEMENTOS INPUT ================== */ /***** Principal *****/ #slick.field { position: relative; width: 100%; clear: both; float: left; margin-bottom: 20px; #slick.field span.icon { background: #ddd; left: 0; color: #fff; font-size: 16px; line-height: 40px; position: absolute; text-align: center; top: 0; height: 100%; width: 38px; Lenguajes Interpretados en el Cliente 13

14 #slick.field input, #slick.field textarea, #slick.field select { border: solid 1px #ddd; color: #333; float: left; font-size: 12px; padding: 12px 20px 10px 50px; width: 100%; #slick.field textarea { max-height: 146px; height: 146px; resize: none; overflow: auto; #slick.field textarea.message { height: 159px; max-height: 159px; #slick.field textarea:focus { height: 200px; max-height: 200px; #slick.field > input:hover, #slick.field > input:focus, #slick.field > select:hover, #slick.field > select:focus, #slick.field > textarea:hover, #slick.field > textarea:focus{ border: solid 1px #333; outline: none; #slick input:hover ~ span.icon, #slick input:focus ~ span.icon, #slick select:hover ~ span.icon, #slick select:focus ~ span.icon, #slick textarea:hover ~ span.icon, #slick textarea:focus ~ span.icon { outline: none; background: #333; /***** Select input *****/ #slick.field select { background: none; background-color: rgba(0,0,0,0); height: auto; z-index: 2; padding-left: 47px; cursor: pointer; -webkit-appearance: none; -moz-appearance: none; appearance: none; #slick select.grayed { color: #999; Lenguajes Interpretados en el Cliente 14

15 #arrow-select, #arrow-select-svg { background: #fff url('../img/select.png') no-repeat 0 11px; width: 44px; height: 35px; position: absolute; right: 1px; top: 1px; pointer-events: none; vertical-align: middle; outline: none; border: none; z-index: 3; #slick select:hover ~ #arrow-select, #slick select:focus ~ #arrow-select, #slick select:hover ~ #arrow-select-svg, #slick select:focus ~ #arrow-select-svg { background: #fff url('../img/select-focus.png') no-repeat 0 screen and (-webkit-min-device-pixel-ratio:0) { #arrow-select-svg { /* Esconde flechas svg en navegadores webkit e IE 9 y 10 (elementos apuntadores no funcionan en estos navegadores) */ display: none; x:-o-prefocus, #arrow-select { display: none; /* Hack para Opera 12 */ /***** Placeholders *****/ /*-- Webkit --*/ #slick input::-webkit-input-placeholder, #slick textarea::-webkit-input-placeholder { color: #999; #slick input:focus::-webkit-input-placeholder, #slick textarea:focus::-webkit-input-placeholder { color: #ccc; /*-- Firefox 19 down --*/ #slick input:-moz-placeholder, #slick textarea:-moz-placeholder { color: #999; #slick input:focus:-moz-placeholder, #slick textarea:focus:-moz-placeholder { color: #ccc; /*-- Firefox 19 up --*/ #slick input::-moz-placeholder, #slick textarea::-moz-placeholder { color: #999; Lenguajes Interpretados en el Cliente 15

16 #slick input:focus::-moz-placeholder, #slick textarea:focus::-moz-placeholder { color: #ccc; /*-- IE */ #slick input:-ms-input-placeholder, #slick textarea:-ms-input-placeholder { color: #999; #slick input:focus:-ms-input-placeholder, #slick textarea:focus:-ms-input-placeholder { color: #ccc; /*-- IE 9 --*/ #slick.ie9-placeholder { color: #999!important; #slick.ie9-placeholder:focus { color: #ccc!important; /***** Validations *****/ #slick.field input:required, #slick.field textarea:required, #slick.field select:required { background: #fff url(../img/required.png) no-repeat 100% 15px; outline: none; box-shadow: none; #slick.field input:hover:invalid, #slick.field textarea:hover:invalid, #slick.field select:hover:invalid { background: #fff url(../img/focused.png) no-repeat 100% 15px; outline: none; box-shadow: none; #slick.field input:required:valid, #slick.field textarea:required:valid, #slick.field select:required:valid { background: #fff url(../img/valid.png) no-repeat 100% 15px; outline: none; box-shadow: none; #slick.field input:focus:invalid, #slick.field textarea:focus:invalid, #slick.field select:focus:invalid { background: #fff url(../img/invalid.png) no-repeat 100% 15px; outline: none; box-shadow: none; /***** Send button *****/ #slick input.send { background: #FF2424; border: none; clear: none; color: #fff; Lenguajes Interpretados en el Cliente 16

17 display: inline-block; float: right; font-size: 12px; margin-right: 10px; outline: none; padding: 6px 28px; text-align: center; text-transform: uppercase; width: auto; #slick input.send:hover, #slick input.send:focus { border: none; outline: none; background: #333; cursor: pointer; /***** Tick checkboxes *****/ #slick label.tick { display: inline-block; float: left; position: relative; width: auto; #slick label.tick:before { background: #fff; border: solid 2px #ddd; content: ""; display: inline-block; height: 16px; position: absolute; width: 16px; #slick label.tick:after { opacity: 0; visibility: hidden; content: ""; position: absolute; width: 8px; height: 4px; background: transparent; top: 6px; left: 5px; border: 2px solid #333; border-top: none; border-right: none; -webkit-transform: rotate(-45deg); -moz-transform: rotate(-45deg); -ms-transform: rotate(-45deg); -o-transform: rotate(-45deg); transform: rotate(-45deg); #slick input:checked + label.tick:after { opacity: 1; visibility: visible; Lenguajes Interpretados en el Cliente 17

18 #slick label.tick span { font-size: 11px; color: #999; padding-left: 26px; #slick label.tick:hover span { color: #333; /* ================== 6. TRANSITIONS ================== */ #slick a, #slick label, #slick input, #slick select, #slick textarea, #slick span.slick-tip, #slick input ~ span.icon, #slick select ~ span.icon, #slick textarea ~ span.icon { -webkit-transition: all 0.2s ease; -moz-transition: all 0.2s ease; -ms-transition: all 0.2s ease; -o-transition: all 0.2s ease; transition: all 0.2s ease; /* ================== 7. MEDIA QUERIES ================== */ /***** Max width 480px screen and (max-width:480px) { #slick { width: 100%; #slick.w-47, #slick.w-30 { width: 100%; #slick.mr-6, #slick.mr-5 { margin-right: 0; #slick.map { margin-top: 20px; #slick.w-30, #slick.mr-5 { margin-bottom: 20px; #slick.field input, #slick.field textarea, #slick.field select { font-size: 16px; #slick p.intro { font-size: 14px; line-height: 20px; #slick input.send { width: 100%; Lenguajes Interpretados en el Cliente 18

19 padding: 12px; float: left; clear: both; font-size: 16px; Resultado de la visualización en un navegador: Ejemplo #2: El siguiente ejemplo muestra una forma de poder calcular la edad exacta de una persona, ingresando la fecha de nacimiento mediante campos de formulario donde debe ingresarse el día, el mes y el año de nacimiento. El cálculo de la edad exacta se hace con respecto a la fecha actual, que tendría que estar bien configurada en el sistema operativo del servidor o computadora donde se ejecuta el script. Guión 1: edadexacta.html <!DOCTYPE html> <html lang="es"> <head> <title>introducir fecha</title> <meta charset="utf-8" /> <link rel="stylesheet" href="css/fonts.css" /> <link rel="stylesheet" href="css/formstyle.css" /> <script type="text/javascript" src="js/calculoedad.js"></script> <!-- Para las versiones anteriores --> <!--[if lt IE 9]> <script src=" <![endif]--> </head> <body> <div class="cover"> <form action="javascript:void(0)" name="frmfechanac" id="contactform"> <h2 class="contact">tu fecha de nacimiento</h2> <span class="contact"> <label for="dia">día:</label> </span> <select name="seldia" id="dia" disabled> <script type="text/javascript"> for(i=1; i<=31; i++){ document.write("<option value='" + i + "'>" + i + "</option>"); </script> </select> Lenguajes Interpretados en el Cliente 19

20 <span class="contact"> <label for="mes">mes:</label> </span> <select name="selmes" id="mes"> <option value='enero' selected>enero</option> <option value='febrero'>febrero</option> <option value='marzo'>marzo</option> <option value='abril'>abril</option> <option value='mayo'>mayo</option> <option value='junio'>junio</option> <option value='julio'>julio</option> <option value='agosto'>agosto</option> <option value='septiembre'>septiembre</option> <option value='octubre'>octubre</option> <option value='noviembre'>noviembre</option> <option value='diciembre'>diciembre</option> </select> <span class="contact"> <label for="txtano">año:</label> </span> <input type="text" value="2014" name="txtano" id="ano" size="4" maxlength="4" /><br /> <input type="button" name="btncalcular" id="calcular" value="tu edad" /> </form> </div> </body> </html> Guión 2: calculoedad.js //Variable para determinar si un año es bisiesto o no var bisiesto = false; //Registrar evento click al presionar el botón de envío function iniciar(){ var dia, mes; var btncalcular = document.getelementbyid("calcular"); //Al producirse un click sobre el botón de envío invocar //a la función edad para calcularla con los datos ingresados if(btncalcular.addeventlistener){ btncalcular.addeventlistener("click", function(){ dia = document.frmfechanac.seldia.options[frmfechanac.seldia.selectedindex].value; mes = document.frmfechanac.selmes.options[frmfechanac.selmes.selectedindex].value; edad(dia, mes, document.frmfechanac.txtano.value);, false); else{ alert(mes); btncalcular.attachevent("onclick", function(){ dia = document.frmfechanac.seldia.options[frmfechanac.seldia.selectedindex].value; mes = document.frmfechanac.selmes.options[frmfechanac.selmes.selectedindex].value; edad(dia, mes, document.frmfechanac.txtano.value); ); //Si se cambia de mes en el campo select name=selmes invocar //a la función llenardias() para volver a rellenar el campo //select dependiente de los días de acuerdo al mes seleccionado var selmes = document.getelementbyid("mes"); if(selmes.addeventlistener){ Lenguajes Interpretados en el Cliente 20

21 selmes.addeventlistener("change", function(){ mes = document.frmfechanac.selmes.options[document.frmfechanac.selmes.selectedindex].value; llenardias(mes, document.frmfechanac.seldia);, false); else if(selmes.attachevent){ selmes.attachevent("onchange", function(){ mes = document.frmfechanac.selmes.options[document.frmfechanac.selmes.selectedindex].value; llenardias(mes, document.frmfechanac.seldia); ); //Del mismo modo, si se ingresa otro año, volver a rellenar //el campo select de los días para considerar si se cambia //a un año bisiesto o no var txtano = document.getelementbyid("ano"); if(txtano.addeventlistener){ txtano.addeventlistener("change", function(){ mes = document.frmfechanac.selmes.options[document.frmfechanac.selmes.selectedindex].value; llenardias(mes, document.frmfechanac.seldia);, false); else if(txtano.attachevent){ txtano.attachevent("onchange", function(){ mes = document.frmfechanac.selmes.options[document.frmfechanac.selmes.selectedindex].value; llenardias(mes, document.frmfechanac.seldia); ); //Función para determinar si un año es bisiesto o no function esbisiesto(anno){ if(anno % 4 == 0 && (anno % 400 == 0 anno % 100!= 0)){ bisiesto = true; else{ bisiesto = false; return bisiesto; //Función para limpiar el menú de selección Días function quitardias(menudias){ for(i=0; i<menudias.options.length; i++){ menudias.options[i] = null; //Función para llenar la caja de texto de los días function llenardias(mes, menudias){ document.frmfechanac.seldia.disabled = false; var i; quitardias(menudias); switch(mes){ case 'Enero': case 'Marzo': case 'Mayo': case 'Julio': case 'Agosto': case 'Octubre': Lenguajes Interpretados en el Cliente 21

22 case 'Diciembre': for(i=0; i<31; i++){ menudias[i] = new Option(parseInt(i+1), parseint(i+1)); break; case 'Abril': case 'Junio': case 'Septiembre': case 'Noviembre': for(i=0; i<30; i++){ menudias[i] = new Option(parseInt(i+1), parseint(i+1)); break; case 'Febrero': if(esbisiesto(document.frmfechanac.txtano.value)){ for(i=0; i<29; i++){ menudias[i] = new Option(parseInt(i+1), parseint(i+1)); else{ for(i=0; i<28; i++){ menudias[i] = new Option(parseInt(i+1), parseint(i+1)); break; //Función para obtener la edad exacta de la persona function edad(dia, mes, annio){ var tusdias, tusmeses, tusannios; var fecactual = new Date(); var year = fecactual.getfullyear(); var month = parseint(fecactual.getmonth()) + 1; var day = fecactual.getdate(); tusdias = day - dia; switch(mes){ case 'Enero': mes = 1; if(tusdias < 0){ tusdias = day - dia + 31; month--; break; case 'Febrero': mes = 2; if(tusdias < 0 && esbisiesto(annio)){ tusdias = day - dia + 29; month--; else if(tusdias < 0 &&!esbisiesto(annio)){ tusdias = day - dia + 28; month--; break; case 'Marzo': mes = 3; if(tusdias < 0){ tusdias = day - dia + 31; month--; Lenguajes Interpretados en el Cliente 22

23 break; case 'Abril': mes = 4; if(tusdias < 0){ tusdias = day - dia + 30; month--; break; case 'Mayo': mes = 5; if(tusdias < 0){ tusdias = day - dia + 31; month--; break; case 'Junio': mes = 6; if(tusdias < 0){ tusdias = day - dia + 30; month--; break; case 'Julio': mes = 7; if(tusdias < 0){ tusdias = day - dia + 31; month--; break; case 'Agosto': mes = 8; if(tusdias < 0){ tusdias = day - dia + 31; month--; break; case 'Septiembre': mes = 9; if(tusdias < 0){ tusdias = day - dia + 30; month--; break; case 'Octubre': mes = 10; if(tusdias < 0){ tusdias = day - dia + 31; month--; break; case 'Noviembre': mes = 11; if(tusdias < 0){ tusdias = day - dia + 30; month--; break; case 'Diciembre': mes = 12; if(tusdias < 0){ tusdias = day - dia + 31; month--; Lenguajes Interpretados en el Cliente 23

24 break; tusmeses = month - mes; if(tusmeses < 0){ tusmeses = month - mes + 12; year--; tusannios = year - annio; alert("tu edad exacta es:\n" + tusannios + " años,\n" + tusmeses + " meses, y\n" + tusdias + " días."); //Asociando función que manejará el evento load al cargar la página if(window.addeventlistener){ window.addeventlistener("load", iniciar, false); else{ window.attachevent("onload", iniciar); Guión 3: fonts.css (Hoja de estilo donde se definen las fuentes a utilizar con { font-family: 'YanoneKaffeesatzRegular'; src: url('../fonts/yanonekaffeesatz-regular-webfont.eot'); src: url('fonts/yanonekaffeesatz-regular-webfont.eot?#iefix') format('embeddedopentype'), url('../fonts/yanonekaffeesatz-regular-webfont.woff') format('woff'), url('../fonts/yanonekaffeesatz-regular-webfont.ttf') format('truetype'), url('../fonts/yanonekaffeesatz-regular-webfont.svg#yanonekaffeesatzregular') format('svg'); font-weight: normal; font-style: { font-family: 'BebasNeueRegular'; src: url('../fonts/bebasneue-webfont.eot'); src: url('../fonts/bebasneue-webfont.eot?#iefix') format('embedded-opentype'), url('../fonts/bebasneue-webfont.woff') format('woff'), url('../fonts/bebasneue-webfont.ttf') format('truetype'), url('../fonts/bebasneue-webfont.svg#bebasneueregular') format('svg'); font-weight: normal; font-style: normal; Guión 4: formstyle.css (Hoja de estilo para los elementos de la página, en especial el formulario). body, div, h1, form, fieldset, input, textarea { margin: 0; padding: 0; border: 0; outline: none; html { height: 100%; body { background: #A4EB90; background-image: -webkit-gradient( linear, left top, left bottom, Lenguajes Interpretados en el Cliente 24

25 color-stop(0, #A4EB90), color-stop(1, #55963F) ); background-image: -o-linear-gradient(bottom, #A4EB90 0%, #55963F 100%); background-image: -moz-linear-gradient(bottom, #A4EB90 0%, #55963F 100%); background-image: -webkit-linear-gradient(bottom, #A4EB90 0%, #55963F 100%); background-image: -ms-linear-gradient(bottom, #A4EB90 0%, #55963F 100%); background-image: linear-gradient(to bottom, #A4EB90 0%, #55963F 100%); font-family: sans-serif;.cover{ background:#ccc; width:700px; margin:auto; padding-left:60px; h2.contact { padding-left: 125px; font-family: 'YanoneKaffeesatzRegular'; font-size: 66px; color: #ff5400; height: 105px; background: url(../images/hatbirthday.png) no-repeat -10px -10px; span.contact { font-size: 24px; margin-bottom: 15px; line-height: 36px; font-family: 'BebasNeueRegular', Arial; color: #4b4b4b; text-shadow: 1px 1px 1px rgba(0, 0, 0, 0.2); input[type="text"] { width: 64px; textarea { width: 600px; height: 275px; select[name="seldia"] { width: 80px; label { color: #ff5400; input, textarea, select { background-color: rgba(255, 255, 255, 0.4); border: 5px solid rgba(122, 192, 0, 0.15); padding: 10px; font-family: 'Keffeesatz', Arial; color: #4b4b4b; font-size: 24px; -webkit-border-radius: 5px; -moz-border-radius: 5px; -o-border-radius: 5px; -ms-border-radius: 5px; border-radius: 5px; margin-bottom: 15px; Lenguajes Interpretados en el Cliente 25

26 margin-top: -10px; input:focus, textarea:focus, select:focus { background-color: rgba(255,255,255,1); border: 5px solid #ff5400; input[type="button"] { background: -webkit-gradient( linear, left bottom, left top, color-stop(0.23, #619702), color-stop(0.62, #7ac000) ); background: -moz-linear-gradient( center bottom, # %, #7ac000 62% ); border: none; cursor: pointer; color: #fff; font-size: 24px; background-color: #7ac000; padding: 5px 36px 8px 36px; -webkit-border-radius: 10px; -moz-border-radius: 10px; -webkitbox-shadow: 2px 2px 5px rgba(0, 0, 0, 0.4); -moz-box-shadow: 2px 2px 5px rgba(0, 0, 0, 0.6); border-bottom: 1px solid rgba(0, 0, 0, 0.4); border-top: 1px solid rgba(255, 255, 255, 0.6); input[type="button"]:hover { background: -webkit-gradient( linear, left bottom, left top, color-stop(0.23, #c34000), color-stop(0.62, #ff5400) ); background: -moz-linear-gradient( center bottom, #c %, #ff % ); color: #fff; border-bottom: 1px solid rgba(0, 0, 0, 0.4); background-color: #ff5400; input[type="button"]:active { top: 1px; Resultado al ejecutar el script activado con los controles de formulario: Lenguajes Interpretados en el Cliente 26

27 Ejemplo #3: En el siguiente ejemplo se muestra cómo crear un script JS que permita indicar en base a una zona horaria mundial seleccionada por el usuario la hora y fecha de esa zona horaria. En este ejemplo se hace uso de los objetos incorporados de JavaScript Date para manejar la fecha y el objeto Math para realizar los cálculos de desfase horario entre las zonas. Guión 1: zonahoraria.html <!DOCTYPE html> <html lang="es"> <head> <title>zona horaria internacional</title> <meta charset="utf-8" /> <link rel="stylesheet" href="css/elegant.css" /> <script type="text/javascript" src="js/zonahoraria.js"></script> <!-- Para las versiones anteriores --> <!--[if lt IE 9]> <script src=" <![endif]--> </head> <body> <header> <h1>zonas del horario internacional</h1> </header> <section> <article> <form name="zonahoraria" class="elegant-aero"> <h1> Zonas horarias del mundo <span>seleccione su zona horaria.</span> </h1> <label> <span>zonas horarias :</span> <select name="zonas" id="zhselect"> <option value="-12">línea internacional de fecha del oeste</option> <option value="-11">isla Midway, Samoa</option> <option value="-10">hawai</option> <option value="-9">alaska</option> <option value="-8">hora del Pacífico (USA y Canadá)</option> <option value="-7">hora de las montañas rocosas (USA y Canadá)</option> <option value="-6">américa Central</option> <option value="-5">hora central (USA y Canadá)</option> <option value="-4">hora del Atlántico (Canadá)</option> <option value="-3">buenos Aires, Asunción, Brasilia, Montevideo</option> <option value="-2">atlántico Central</option> <option value="-1">azores</option> <option value="0" selected="selected">hora del meridiano de Greenwich, Londres, Dublin</option> <option value="+1">paris, Madrid, Barcelona, Roma</option> <option value="+2">el Cairo</option> <option value="+3">nairobi</option> <option value="+4">bakú</option> <option value="+5">ekaterimburgo</option> <option value="+6">astana</option> <option value="+7">bangkok</option> Lenguajes Interpretados en el Cliente 27

28 <option value="+8">ulán Bator</option> <option value="+9">tokio</option> <option value="+10">sidney</option> <option value="+11">islas Salomón</option> <option value="+12">wellington</option> </select> </label> <label> <span>la hora en esta zona es :</span> <input type="text" name="hour" id="hour" placeholder="(zona horaria)" readonly="readonly" /> </label> <label> <span> </span> <input type="button" class="button" value="cambiar" /> </label> </form> </article> </section> </body> </html> Guión 2: zonahoraria.js //La fecha del día en la zona del cliente web //usando el objeto Date de JavaScript var fechahoy = new Date(); //Cálculo del desfase en el huso horario para hacer //luego el ajuste con la zona horaria seleccionada //en el elemento select del formulario var desfase = -(Math.round(fechaHoy.getTimezoneOffset()/60)) + 12; //Registrar evento click del ratón al presionar botones de envío function iniciar(){ var select = document.getelementbyid("zhselect"); if(select.addeventlistener){ select.addeventlistener("change", gethoralocal, false); else{ select.attachevent("onchange", gethoralocal); //Función gethoralocal() //Calcula la hora en la zona horaria seleccionada function gethoralocal(){ var fechahoy = new Date(); //Ajustar el desfase horario respecto a la zona seleccionada. //Por ejemplo, la zona horaria para América Central está //en el índice 6 de la colección de opciones del elemento select. //Si un usuario selecionara la zona horaria de Tokio que está //en el índice 21 de la colección el cálculo se realizaría así: //21 - desfase del cliente (zona horaria de América Central) = 15 var zh = document.zonahoraria.zonas.selectedindex - desfase; //Sumar (o restar) las horas de desfase respecto a la hora //local del cliente fechahoy.sethours(fechahoy.gethours() + zh); //Informar la hora local del huso horario elegido document.zonahoraria.hour.value = fechahoy.tolocalestring(); Lenguajes Interpretados en el Cliente 28

29 //Asociando función que manejará el evento load al cargar la página if(window.addeventlistener){ window.addeventlistener("load", iniciar, false); else{ window.attachevent("onload", iniciar); Guión 3: elegant.css /* Estilos básicos para toda la página */ * { margin: 0; padding: 0; body { font-size: 15px; background-image: -webkit-gradient( linear, left top, left bottom, color-stop(0, #EDCACE), color-stop(1, #F0CEDD) ); background-image: -o-linear-gradient(bottom, #EDCACE 0%, #F0CEDD 100%); background-image: -moz-linear-gradient(bottom, #EDCACE 0%, #F0CEDD 100%); background-image: -webkit-linear-gradient(bottom, #EDCACE 0%, #F0CEDD 100%); background-image: -ms-linear-gradient(bottom, #EDCACE 0%, #F0CEDD 100%); background-image: linear-gradient(to bottom, #EDCACE 0%, #F0CEDD 100%); header h1 { font: bold 2.2em/24px Tahoma,Geneva,"Liberation Sans"; color: #091363; padding: 24px 0; text-align: center; text-shadow: 2px 2px 0px #abf, 4px 4px 0px #909090; /* Elegant Aero para el formulario */.elegant-aero { margin-left:auto; margin-right:auto; max-width: 500px; background: #D2E9FF; padding: 20px 20px 20px 20px; font: 12px Arial, Helvetica, sans-serif; color: #666;.elegant-aero h1 { font: 24px "Trebuchet MS",Arial,Helvetica,"Liberation Sans"; padding: 10px 10px 10px 20px; display: block; background: #C0E1FF; border-bottom: 1px solid #B8DDFF; margin: -20px -20px 15px;.elegant-aero h1>span { display: block; Lenguajes Interpretados en el Cliente 29

30 font-size: 11px;.elegant-aero label>span { float: left; margin-top: 10px; color: #5E5E5E;.elegant-aero label { display: block; margin: 0px 0px 5px;.elegant-aero label>span { float: left; width: 20%; text-align: right; padding-right: 15px; margin-top: 10px; font-weight: bold;.elegant-aero input[type="text"],.elegant-aero input[type=" "],.elegant-aero textarea,.elegant-aero select { color: #888; width: 70%; padding: 0px 0px 0px 5px; border: 1px solid #C5E2FF; background: #FBFBFB; outline: 0; -webkit-box-shadow:inset 0px 1px 6px #ECF3F5; box-shadow: inset 0px 1px 6px #ECF3F5; font: em/25px Arial, Helvetica, sans-serif; height: 30px; line-height:15px; margin: 2px 6px 16px 0px;.elegant-aero textarea{ height:100px; padding: 5px 0px 0px 5px; width: 70%;.elegant-aero select { background: #fbfbfb url('../img/down-arrow.png') no-repeat right; background: #fbfbfb url('../img/down-arrow.png') no-repeat right; appearance:none; -webkit-appearance:none; -moz-appearance: none; -o-appearance:none; -ms-appearance:none; text-indent: 0.01px; text-overflow: ''; width: 70%;.elegant-aero.button{ padding: 10px 30px 10px 30px; background: #66C1E4; Lenguajes Interpretados en el Cliente 30

31 border: none; color: #FFF; box-shadow: 1px 1px 1px #4C6E91; -webkit-box-shadow: 1px 1px 1px #4C6E91; -moz-box-shadow: 1px 1px 1px #4C6E91; text-shadow: 1px 1px 1px #5079A3;.elegant-aero.button:hover{ background: #3EB1DD; Resultado al ejecutar el script con un navegador: Ejemplo #4: Ejemplo que permite ingresar en un formulario datos de un libro que luego son almacenados en propiedades de un objeto libro definido con el objeto Object de JavaScript. Se verifica que los datos obtenidos sean correctos, se limpian los campos del formulario y finalmente se construye una tabla HTML con uno de los métodos del objeto donde se muestran los datos ya almacenados en las propiedades de ese objeto creado. Guión 1: libros.html <!DOCTYPE html> <html lang="es"> <head> Lenguajes Interpretados en el Cliente 31

32 <title>creación de objetos</title> <meta charset="utf-8" /> <link rel="stylesheet" href="css/font.css" /> <link rel="stylesheet" href="css/masked.css" /> <link rel="stylesheet" href="css/libro.css" /> <script type="text/javascript" src="js/libro.js"></script> </head> <body> <div class="masked"> <h1>información del libro</h1> </div> <form name="frmbook" id="frmbook"> <table> <tr> <td>autor: </td> <td> <input type="text" name="txtautor" id="txtautor" maxlength="40" /> </td> </tr> <tr> <td>título: </td> <td> <input type="text" name="txtitulo" id="txtitulo" maxlength="30" /> </td> </tr> <tr> <td>editorial: </td> <td> <select name="seleditorial" size="1"> <option value="a" selected="selected">mc-graw Hill</option> <option value="b">pearson</option> <option value="a">alfa-omega</option> <option value="a">anaya</option> </select> </td> </tr> <tr> <td>edición: </td> <td> <select name="seledicion" size="1"> <option value="a" selected="selected">1ra</option> <option value="b">2da</option> <option value="c">3ra</option> <option value="d">4ta</option> <option value="e">5ta</option> <option value="f">6ta</option> </select> </td> </tr> <tr> <td>país: </td> <td> <input type="text" name="txtpais" id="txtpais" maxlength="36" /> </td> </tr> <tr> <td colspan="2" class="combinar"> <input type="button" name="mostrar" id="mostrar" value="enviar" class="boton" /> </td> </tr> </table> </form> </body> Lenguajes Interpretados en el Cliente 32

33 </html> Guión 2: libro.js //Creando el objeto var book = new Object(); //Registrar evento click del ratón al presionar botones de envío function iniciar(){ var showinfo = document.getelementbyid("mostrar"); if(showinfo.addeventlistener){ showinfo.addeventlistener("click", function(){ createobject(document.frmbook);, false); else{ showinfo.attachevent("onclick", function(){ createobject(document.frmbook); ); // Creando el nuevo objeto function createobject(form){ book.autor = form.txtautor.value; book.titulo = form.txtitulo.value; book.editorial = form.seleditorial.options[form.seleditorial.selectedindex].text; book.edicion = form.seledicion.options[form.seledicion.selectedindex].text; book.pais = form.txtpais.value; showproperties(book, "InfoBook"); function showproperties(objeto, objname){ var infbook = ""; var tblbook = ""; for(var i in objeto){ infbook = infbook + objname + "." + i + " = " + objeto[i] + "\n"; if(!confirm(infbook + "\n\n Es esta información correcta?")){ frmbook.txtautor.value = ""; frmbook.txtitulo.value = ""; frmbook.seleditorial.value = "a"; frmbook.seledicion.value = "a"; frmbook.txtpais.value = ""; tblbook += "<!DOCTYPE html>\n"; tblbook += "<html lang=\"es\">\n"; tblbook += "<head>\n\t"; tblbook += "<title>información del libro</title>\n"; tblbook += "<meta charset=\"utf-8\" />"; tblbook += "<link rel=\"stylesheet\" href=\"css/infolibro.css\"/>\n"; tblbook += "</head>\n"; tblbook += "<body>\n"; tblbook += "<table class=\"bookinfo\">"; tblbook += "<thead>\n\t<tr>\n\t\t"; tblbook += "<th>título</th>\n\t\t"; tblbook += "<th>autor</th>\n\t\t"; tblbook += "<th>editorial</th>\n\t\t"; tblbook += "<th>edición</th>\n\t\t"; tblbook += "<th>país</th>\n\t\t"; tblbook += "</tr>\n\t</thead>\n"; tblbook += "<tbody>\n\t"; tblbook += "<tr>\n\t\t"; Lenguajes Interpretados en el Cliente 33

34 tblbook += "<td>" + book.titulo + "</td>\n\t\t"; tblbook += "<td>" + book.autor + "</td>\n\t\t"; tblbook += "<td>" + book.editorial + "</td>\n\t\t"; tblbook += "<td>" + book.edicion + "</td>\n\t\t"; tblbook += "<td>" + book.pais + "</td>\n\t\t"; tblbook += "</tr></tbody>\n"; tblbook += "</table>\n"; tblbook += "</head>\n"; tblbook += "</html>\n"; document.write(tblbook); //Asociando función que manejará el evento load al cargar la página if(window.addeventlistener){ window.addeventlistener("load", iniciar, false); else{ window.attachevent("onload", iniciar); Guión 3: { font-family: 'LeagueGothicRegular'; src: url('../fonts/league_gothic.eot'); src: url('../fonts/league_gothic.woff') format('woff'), url('../fonts/league_gothic.otf') format('opentype'), url('../fonts/league_gothic.svg#leaguegothic') format('svg'); Guión 4: libro.css * { margin: 0; padding: 0;.masked{ color:#fff; margin-top: 20px; h1 { font-family: "LeagueGothicRegular",Lucida,sans-serif; font-size: 100px; line-height: 1; letter-spacing: -3px; margin-bottom: 10px; text-align:center; text-transform: uppercase; table { border-style:outset; border-width:12px; border-color:rgb(166,199,166); margin: 12px auto; td { background-color:rgb(150,150,255); font-family:"trebuchet MS"; font-size:9pt; font-weight:300; Lenguajes Interpretados en el Cliente 34

35 padding: 2.5px 3px; text-align:left; input, select { background-color:rgb(180,220,200); color:rgb(30,40,90); font-family:"trebuchet MS"; font-weight:bold; font-size:8pt; height: 22px; width: 160px;.combinar { background-color:rgb(180,220,200); text-align:center;.boton { background-color:rgb(150,150,255); color:rgb(30,40,90); font-family:trebuchet MS; font-size:8pt; font-weight:bold; text-align:center; Guión 5: masked.css.masked{ background: url(../img/paint.png) repeat, white; -ms-text-fill-color: transparent; -ms-background-clip: text; -ms-animation-name: masked-animation; -ms-animation-duration: 40s; -ms-animation-iteration-count: infinite; -ms-animation-timing-function: linear; -moz-text-fill-color: transparent; -moz-background-clip: text; -moz-animation-name: masked-animation; -moz-animation-duration: 40s; -moz-animation-iteration-count: infinite; -moz-animation-timing-function: linear; -o-text-fill-color: transparent; -o-background-clip: text; -o-animation-name: masked-animation; -o-animation-duration: 40s; -o-animation-iteration-count: infinite; -o-animation-timing-function: linear; -webkit-text-fill-color: transparent; -webkit-background-clip: text; -webkit-animation-name: masked-animation; -webkit-animation-duration: 40s; -webkit-animation-iteration-count: infinite; -webkit-animation-timing-function: linear; text-fill-color: transparent; background-clip: text; animation-name: masked-animation; animation-duration: 40s; animation-iteration-count: infinite; animation-timing-function: linear; Lenguajes Interpretados en el Cliente 35

36 @-webkit-keyframes masked-animation { 0% {background-position: left bottom; 100% {background-position: right bottom; Guión 6: infolibro.css table.bookinfo { border-color: #999999; border-collapse: collapse; border-width: 1px; color:#333333; font-family: verdana,arial,sans-serif; font-size:11px; margin: 26px auto; width: 42%; table.bookinfo th { padding: 6px 8px; background: #d5e3e4; background: url( LnczLm9yZy8yMDAwL3N2ZyIgd2lkdGg9IjEwMCUiIGhlaWdodD0iMTAwJSIgdmlld0JveD0iMCAwIDEgMSIgcHJlc2 VydmVBc3BlY3RSYXRpbz0ibm9uZSI+CiAgPGxpbmVhckdyYWRpZW50IGlkPSJncmFkLXVjZ2ctZ2VuZXJhdGVkIiBn cmfkawvudfvuaxrzpsj1c2vyu3bhy2vpblvzzsigede9ijaliib5mt0imcuiihgypsiwjsigeti9ijewmcuipgogic AgPHN0b3Agb2Zmc2V0PSIwJSIgc3RvcC1jb2xvcj0iI2Q1ZTNlNCIgc3RvcC1vcGFjaXR5PSIxIi8+CiAgICA8c3Rv ccbvzmzzzxq9ijqwjsigc3rvcc1jb2xvcj0ii2njzgvlmcigc3rvcc1vcgfjaxr5psixii8+ciagica8c3rvccbvzm ZzZXQ9IjEwMCUiIHN0b3AtY29sb3I9IiNiM2M4Y2MiIHN0b3Atb3BhY2l0eT0iMSIvPgogIDwvbGluZWFyR3JhZGll bnq+ciagphjly3qged0imciget0imcigd2lkdgg9ijeiighlawdodd0imsigzmlsbd0idxjskcnncmfklxvjz2ctz2 VuZXJhdGVkKSIgLz4KPC9zdmc+); background: -moz-linear-gradient(top, #d5e3e4 0%, #ccdee0 40%, #b3c8cc 100%); background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,#d5e3e4), color-stop(40%,#ccdee0), color-stop(100%,#b3c8cc)); background: -webkit-linear-gradient(top, #d5e3e4 0%,#ccdee0 40%,#b3c8cc 100%); background: -o-linear-gradient(top, #d5e3e4 0%,#ccdee0 40%,#b3c8cc 100%); background: -ms-linear-gradient(top, #d5e3e4 0%,#ccdee0 40%,#b3c8cc 100%); background: linear-gradient(to bottom, #d5e3e4 0%,#ccdee0 40%,#b3c8cc 100%); border: 1px solid #999999; table.bookinfo td { padding: 6px 8px; background: #ebecda; background: url( LnczLm9yZy8yMDAwL3N2ZyIgd2lkdGg9IjEwMCUiIGhlaWdodD0iMTAwJSIgdmlld0JveD0iMCAwIDEgMSIgcHJlc2 VydmVBc3BlY3RSYXRpbz0ibm9uZSI+CiAgPGxpbmVhckdyYWRpZW50IGlkPSJncmFkLXVjZ2ctZ2VuZXJhdGVkIiBn cmfkawvudfvuaxrzpsj1c2vyu3bhy2vpblvzzsigede9ijaliib5mt0imcuiihgypsiwjsigeti9ijewmcuipgogic AgPHN0b3Agb2Zmc2V0PSIwJSIgc3RvcC1jb2xvcj0iI2ViZWNkYSIgc3RvcC1vcGFjaXR5PSIxIi8+CiAgICA8c3Rv ccbvzmzzzxq9ijqwjsigc3rvcc1jb2xvcj0ii2uwztbjniigc3rvcc1vcgfjaxr5psixii8+ciagica8c3rvccbvzm ZzZXQ9IjEwMCUiIHN0b3AtY29sb3I9IiNjZWNlYjciIHN0b3Atb3BhY2l0eT0iMSIvPgogIDwvbGluZWFyR3JhZGll bnq+ciagphjly3qged0imciget0imcigd2lkdgg9ijeiighlawdodd0imsigzmlsbd0idxjskcnncmfklxvjz2ctz2 VuZXJhdGVkKSIgLz4KPC9zdmc+); background: -moz-linear-gradient(top, #ebecda 0%, #e0e0c6 40%, #ceceb7 100%); background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,#ebecda), color-stop(40%,#e0e0c6), color-stop(100%,#ceceb7)); background: -webkit-linear-gradient(top, #ebecda 0%,#e0e0c6 40%,#ceceb7 100%); background: -o-linear-gradient(top, #ebecda 0%,#e0e0c6 40%,#ceceb7 100%); background: -ms-linear-gradient(top, #ebecda 0%,#e0e0c6 40%,#ceceb7 100%); background: linear-gradient(to bottom, #ebecda 0%,#e0e0c6 40%,#ceceb7 100%); border: 1px solid #999999; Lenguajes Interpretados en el Cliente 36

37 table.bookinfo th p{ margin:0px; padding:8px; border-top: 1px solid #eefafc; border-bottom:0px; border-left: 1px solid #eefafc; border-right:0px; table.bookinfo td p{ margin:0px; padding:8px; border-top: 1px solid #fcfdec; border-bottom:0px; border-left: 1px solid #fcfdec;; border-right:0px; Resultado: Ejemplo #5: Este ejemplo muestra cómo controlar con JavaScript las opciones de un campo select dependiente de otro campo select. De modo que al cambiar la opción seleccionado en el campo select principal, se limpia por completo el campo select dependiente y se vuelve a llenar inmediatamente con las opciones que se corresponden con la opción seleccionada. Guión 1: carro.html <!DOCTYPE html> <html lang="es"> <head> <title>clases y objetos</title> <meta charset="utf-8" /> Lenguajes Interpretados en el Cliente 37

38 <link rel="stylesheet" href="css/font.css" /> <link rel="stylesheet" href="css/carform.css" /> <script type="text/javascript" src="js/showcar.js"></script> </head> <body> <header id="insetbgd"> <h1>ejemplo del uso de objetos</h1> </header> <section> <article> <form name="frmcar" id="frmcar"> <fieldset id="fldcar" class="group"> <legend><span class="labelgroup">datos del carro</span></legend> <label for="selfab">fabricante: </label> <select name="selfab" id="selfab"> <option value="toyota">toyota</option> <option value="nissan">nissan</option> <option value="hyundai">hyundai</option> <option value="volkswagen">volkswagen</option> <option value="chevrolet">chevrolet</option> <option value="honda">honda</option> <option value="mitsubishi">mitsubishi</option> </select> <label for="selmod">modelo: </label> <select name="selmod" id="selmod"> <option value="corolla">corolla</option> <option value="echo">echo</option> <option value="yaris">yaris</option> <option value="avensis">avensis</option> <option value="camry">camry</option> <option value="land Cruiser">Land Cruiser</option> <option value="4 Runner">4 Runner</option> <option value="hilux">hilux</option> </select> <label for="radcolor" class="colores">color:</label><br /> <input type="radio" value="blanco" alt="marque el color del carro" id="radcolor" name="radcolor" /> <label for="radcolor" class="colores">blanco</label><br> <input type="radio" value="negro" alt="marque el color del carro" id="radcolor" name="radcolor" /> <label for="radcolor" class="colores">negro</label><br> <input type="radio" value="gris" alt="marque el color del carro" id="radcolor" name="radcolor" /> <label for="radcolor" class="colores">gris</label><br> <input type="radio" value="azul" alt="marque el color del carro" id="radcolor" name="radcolor" /> <label for="radcolor" class="colores">azul</label><br> <input type="radio" value="verde" alt="marque el color del carro" id="radcolor" name="radcolor" /> <label for="radcolor" class="colores">verde</label><br> <input type="radio" value="rojo" alt="marque el color del carro" id="radcolor" name="radcolor" /> <label for="radcolor" class="colores">rojo</label><br> <input type="radio" value="amarillo" alt="marque el color del carro" id="radcolor" name="radcolor" /> <label for="radcolor" class="colores">amarillo</label><br> <input type="radio" value="beige" alt="marque el color del carro" id="radcolor" name="radcolor" /> <label for="radcolor" class="colores">beige</label> <br /> <label for="txtanio">año: </label> <input type="number" name="txtanio" placeholder="2014" maxlength="4" /> <input type="button" name="btnenviar" id="enviar" value="enviar" /> </fieldset> Lenguajes Interpretados en el Cliente 38

39 </form> </article> </section> </body> </html> Guión 2: showcar.js //Registrar evento click al presionar botones de envío //y evento change al cambiar de opción en el elemento select function iniciar(){ var select = document.getelementbyid("selfab"); var button = document.getelementbyid("enviar"); //Al producirse en evento change en el elemento select //invocar a la función addoptions para volver a llenar //el select dependiente con los datos adecuados if(select.addeventlistener){ select.addeventlistener("change", function(){ addoptions(marcas[this.options[this.selectedindex].text], document.frmcar.selmod);, false); else{ select.attachevent("onchange", function(){ addoptions(marcas[this.options[this.selectedindex].text], document.frmcar.selmod); ); //Al producirse un click sobre el botón de envío //invocar los métodos del objeto carro que mostrarán //los valores ingresados en el formulario if(button.addeventlistener){ button.addeventlistener("click", function(){ var seleccion = showradioselected(document.frmcar.radcolor); carro.pedido(document.frmcar.selfab.value, document.frmcar.selmod.value, seleccion, document.frmcar.txtanio.value); carro.mostrar();, false); else{ button.attachevent("onclik", function(){ var seleccion = showradioselected(document.frmcar.radcolor); carro.pedido(document.frmcar.selfab.value, seleccion, document.frmcar.txtanio.value); carro.mostrar(); ); document.frmcar.selmod.value, //Inicializando matriz para manejar las marcas y sus respectivos modelos var marcas = new Array(7); marcas["toyota"] = ["Corolla", "Echo", "Yaris", "Avensis", "Camry", "Land Cruiser", "4 Runner", "Hilux"]; marcas["nissan"] = ["Sentra", "Platina", "Almera", "Altima", "Tiida", "Pathfinder", "Patrol", "X-Trail", "Frontier"]; marcas["hyundai"] = ["Elantra", "Accent", "Coupé", "Santa Fe", "i30"]; marcas["volkswagen"] = ["Golf", "Jetta", "Passat", "Phaeton", "Thunder Bunny", "Touareg", "Saveiro"]; marcas["chevrolet"] = ["Optra", "Aveo", "Cobalt", "Malibu", "Corvette", "Chevy", "Avalanche", "Trailblazer"]; marcas["honda"] = ["Civic", "Acura", "Accord", "Fit", "Odyssey", "CR-V", "Pilot", "RidgeLine"]; Lenguajes Interpretados en el Cliente 39

40 marcas["mitsubishi"] = ["Lancer", "Galant", "Eclipse", "Montero", "Nativa", "Outlander", "L200"]; //Creando el objeto carro con el constructor Object() var carro = new Object(); //Propiedades del objeto carro.fabricante = ""; carro.modelo = ""; carro.color = ""; carro.anio = ""; //Métodos del objeto carro.pedido = function(fab, mod, col, an){ carro.fabricante = fab; carro.modelo = mod; carro.color = col; carro.anio = an; carro.mostrar = function(){ document.write("<!doctype html>\n"); document.write("<html lang=\"es\">\n"); document.write("<head>\n\t"); document.write("<title>datos del carro</title>\n"); document.write("<meta charset=\"utf-8\" />"); document.write("<link rel=\"stylesheet\" href=\"css/carinfo.css\"/>\n"); document.write("</head>\n"); document.write("<body>\n"); document.write("<table class=\"carinfo\"><tr>\n"); document.write("<th colspan=\"2\">datos del carro</th>\n"); document.write("<tr><td>fabricante: </td>\n"); document.write("<td>" + carro.fabricante + "</td></tr>\n"); document.write("<tr><td>modelo: </td>\n"); document.write("<td>" + carro.modelo + "</td></tr>\n"); document.write("<tr><td>color: </td>\n"); document.write("<td>" + carro.color + "</td></tr>\n"); document.write("<tr><td>año: </td>\n"); document.write("<td>" + carro.anio + "</td></tr>\n"); document.write("</tr></table>\n"); document.write("</head>\n"); document.write("</html>\n"); function showradioselected(radiogroup){ var seleccionado; var numradios = radiogroup.length; for(var i=0; i<numradios; i++){ if(radiogroup[i].checked){ seleccionado = radiogroup[i].value; return seleccionado; function removeoptions(optionmenu){ for(i=0; i<optionmenu.options.length; i++){ optionmenu.options[i] = null; function addoptions(optionlist, optionmenu){ var i=0; removeoptions(optionmenu); //Limpia las opciones for(i=0; i<optionlist.length; i++){ optionmenu[i] = new Option(optionList[i], optionlist[i]); Lenguajes Interpretados en el Cliente 40

41 //Asociando función que manejará el evento load al cargar la página if(window.addeventlistener){ window.addeventlistener("load", iniciar, false); else{ window.attachevent("onload", iniciar); Guión 3: { font-family: 'LatoBlack'; src: url('../fonts/lato/lato-black.eot'); /* IE9 Compat Modes */ src: url('../fonts/lato/lato-black.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */ url('../fonts/lato/lato-black.woff') format('woff'), /* Modern Browsers */ url('../fonts/lato/lato-black.ttf') format('truetype'); font-style: normal; font-weight: normal; text-rendering: { font-family: 'LatoLight'; src: url('../fonts/lato/lato-light.eot'); /* IE9 Compat Modes */ src: url('../fonts/lato/lato-light.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */ url('../fonts/lato/lato-light.woff') format('woff'), /* Modern Browsers */ url('../fonts/lato/lato-light.ttf') format('truetype'); font-style: normal; font-weight: normal; text-rendering: optimizelegibility; Guión 4: carform.css body { font-size: 15px; #insetbgd { background: #012266; /* Old browsers */ background: -moz-linear-gradient(top, # %, #426dc9 100%); /* FF3.6+ */ background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,#012266), color-stop(100%,#426dc9)); /* Chrome,Safari4+ */ background: -webkit-linear-gradient(top, # %,#426dc9 100%); /* Chrome10+,Safari5.1+ */ background: -o-linear-gradient(top, # %,#426dc9 100%); /* Opera */ background: -ms-linear-gradient(top, # %,#426dc9 100%); /* IE10+ */ background: linear-gradient(to bottom, # %,#426dc9 100%); /* W3C */ filter: progid:dximagetransform.microsoft.gradient( startcolorstr='#012266', endcolorstr='#426dc9',gradienttype=0 ); /* IE6-9 */ margin: 0 auto; height: 100px; width: 650px; #insetbgd h1 { color: #191970; font-family: Rockwell, Georgia, "Times New Roman", Times, serif; font-size: 3em; Lenguajes Interpretados en el Cliente 41

42 padding-top: 20px; text-align: center; text-shadow: rgba(0,0,0,0.5) -1px 0, rgba(0,0,0,0.3) 0-1px, rgba(255,255,255,0.5) 0 1px, rgba(0,0,0,0.3) -1px -2px; form { margin-bottom: 22px; margin: 20px auto; width: 42%; fieldset { border-color: #012266; -webkit-border-radius: 10px; -moz-border-radius: 10px; -o-border-radius: 10px; -ms-border-radius: 10px; border-radius: 10px;.group input,.group select,.group textarea { font: 300 1em/22px "LatoLight","Open Sans","Helvetica Neue",Helvetica,Arial,"Liberation Sans",sans-serif;.group span.labelgroup { background: #012266; /* Old browsers */ background: -moz-linear-gradient(top, # %, #426dc9 100%); /* FF3.6+ */ background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,#012266), color-stop(100%,#426dc9)); /* Chrome,Safari4+ */ background: -webkit-linear-gradient(top, # %,#426dc9 100%); /* Chrome10+,Safari5.1+ */ background: -o-linear-gradient(top, # %,#426dc9 100%); /* Opera */ background: -ms-linear-gradient(top, # %,#426dc9 100%); /* IE10+ */ background: linear-gradient(to bottom, # %,#426dc9 100%); /* W3C */ filter: progid:dximagetransform.microsoft.gradient( startcolorstr='#012266', endcolorstr='#426dc9',gradienttype=0 ); /* IE6-9 */ -webkit-border-top-left-radius: 10px; -webkit-border-top-right-radius: 10px; -moz-border-radius-topleft: 10px; -moz-border-radius-topright: 10px; -o-border-top-left-radius: 10px; -o-border-top-right-radius: 10px; -ms-border-top-left-radius: 10px; -ms-border-top-right-radius: 10px; border-top-left-radius: 10px; border-top-right-radius: 10px; color: #ece9ef; display: block; font: Bold 1em/24px "LatoBlack","Open Sans","Helvetica Neue",Helvetica,Arial,"Liberation Sans",sans-serif; padding: 6px 8px;.group label { color: #191970; cursor: pointer; Lenguajes Interpretados en el Cliente 42

43 font-family: "LatoLight","Open Sans","Helvetica Neue",Helvetica,Arial,"Liberation Sans"; font-weight: 600;.group label.colores { display: inline-block; width: 25%;.group input,.group select,.group textarea { border: 1px solid #c6c9cc; border-radius: 5px; color: #426dc9; display: block; margin: 5px 0 8px 0; padding: 3px 4px;.group input,.group textarea { width: 100%;.group input[type="radio"],.group input[type="checkbox"] { display: inline-block; width: 4%;.group input[type="number"] { width: 12%;.group select { height: 28px; width: auto;.group textarea { height: 78px;.group input[type="button"] { background: #FF6347; border: 0; color: #f6f3f9; font-size: 0.9em; padding: 8px 16px; width: 26%;.group input[type="button"]:hover { background: #FF4500; color: #f6f3f9; Guión 5: carinfo.css table.carinfo { border-color: #999999; Lenguajes Interpretados en el Cliente 43

44 border-collapse: collapse; border-width: 1px; color:#333333; font-family: verdana,arial,sans-serif; font-size:11px; margin: 26px auto; width: 24%; table.carinfo th { padding: 6px 8px; background: #d5e3e4; background: url( LnczLm9yZy8yMDAwL3N2ZyIgd2lkdGg9IjEwMCUiIGhlaWdodD0iMTAwJSIgdmlld0JveD0iMCAwIDEgMSIgcHJlc2 VydmVBc3BlY3RSYXRpbz0ibm9uZSI+CiAgPGxpbmVhckdyYWRpZW50IGlkPSJncmFkLXVjZ2ctZ2VuZXJhdGVkIiBn cmfkawvudfvuaxrzpsj1c2vyu3bhy2vpblvzzsigede9ijaliib5mt0imcuiihgypsiwjsigeti9ijewmcuipgogic AgPHN0b3Agb2Zmc2V0PSIwJSIgc3RvcC1jb2xvcj0iI2Q1ZTNlNCIgc3RvcC1vcGFjaXR5PSIxIi8+CiAgICA8c3Rv ccbvzmzzzxq9ijqwjsigc3rvcc1jb2xvcj0ii2njzgvlmcigc3rvcc1vcgfjaxr5psixii8+ciagica8c3rvccbvzm ZzZXQ9IjEwMCUiIHN0b3AtY29sb3I9IiNiM2M4Y2MiIHN0b3Atb3BhY2l0eT0iMSIvPgogIDwvbGluZWFyR3JhZGll bnq+ciagphjly3qged0imciget0imcigd2lkdgg9ijeiighlawdodd0imsigzmlsbd0idxjskcnncmfklxvjz2ctz2 VuZXJhdGVkKSIgLz4KPC9zdmc+); background: -moz-linear-gradient(top, #d5e3e4 0%, #ccdee0 40%, #b3c8cc 100%); background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,#d5e3e4), color-stop(40%,#ccdee0), color-stop(100%,#b3c8cc)); background: -webkit-linear-gradient(top, #d5e3e4 0%,#ccdee0 40%,#b3c8cc 100%); background: -o-linear-gradient(top, #d5e3e4 0%,#ccdee0 40%,#b3c8cc 100%); background: -ms-linear-gradient(top, #d5e3e4 0%,#ccdee0 40%,#b3c8cc 100%); background: linear-gradient(to bottom, #d5e3e4 0%,#ccdee0 40%,#b3c8cc 100%); border: 1px solid #999999; table.carinfo td { padding: 6px 8px; background: #ebecda; background: url( LnczLm9yZy8yMDAwL3N2ZyIgd2lkdGg9IjEwMCUiIGhlaWdodD0iMTAwJSIgdmlld0JveD0iMCAwIDEgMSIgcHJlc2 VydmVBc3BlY3RSYXRpbz0ibm9uZSI+CiAgPGxpbmVhckdyYWRpZW50IGlkPSJncmFkLXVjZ2ctZ2VuZXJhdGVkIiBn cmfkawvudfvuaxrzpsj1c2vyu3bhy2vpblvzzsigede9ijaliib5mt0imcuiihgypsiwjsigeti9ijewmcuipgogic AgPHN0b3Agb2Zmc2V0PSIwJSIgc3RvcC1jb2xvcj0iI2ViZWNkYSIgc3RvcC1vcGFjaXR5PSIxIi8+CiAgICA8c3Rv ccbvzmzzzxq9ijqwjsigc3rvcc1jb2xvcj0ii2uwztbjniigc3rvcc1vcgfjaxr5psixii8+ciagica8c3rvccbvzm ZzZXQ9IjEwMCUiIHN0b3AtY29sb3I9IiNjZWNlYjciIHN0b3Atb3BhY2l0eT0iMSIvPgogIDwvbGluZWFyR3JhZGll bnq+ciagphjly3qged0imciget0imcigd2lkdgg9ijeiighlawdodd0imsigzmlsbd0idxjskcnncmfklxvjz2ctz2 VuZXJhdGVkKSIgLz4KPC9zdmc+); background: -moz-linear-gradient(top, #ebecda 0%, #e0e0c6 40%, #ceceb7 100%); background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,#ebecda), color-stop(40%,#e0e0c6), color-stop(100%,#ceceb7)); background: -webkit-linear-gradient(top, #ebecda 0%,#e0e0c6 40%,#ceceb7 100%); background: -o-linear-gradient(top, #ebecda 0%,#e0e0c6 40%,#ceceb7 100%); background: -ms-linear-gradient(top, #ebecda 0%,#e0e0c6 40%,#ceceb7 100%); background: linear-gradient(to bottom, #ebecda 0%,#e0e0c6 40%,#ceceb7 100%); border: 1px solid #999999; table.carinfo th p{ margin:0px; padding:8px; border-top: 1px solid #eefafc; border-bottom:0px; border-left: 1px solid #eefafc; border-right:0px; Lenguajes Interpretados en el Cliente 44

45 table.carinfo td p{ margin:0px; padding:8px; border-top: 1px solid #fcfdec; border-bottom:0px; border-left: 1px solid #fcfdec;; border-right:0px; Resultado en el navegador: Ejemplo #6: El siguiente ejemplo simula el proceso de matrícula de un alumno. Para ello se llenan los campos de un formulario con datos básicos. Con un script JS se obtienen los datos ingresados en los campos del formulario y se crean propiedades para un Guión 1: matricula.html <!DOCTYPE html> <html lang="es"> <head> <title>crear y editar tablas con JS</title> <meta charset="utf-8" /> <link rel="stylesheet" href="css/modernform.css" /> <script type="text/javascript" src="js/alumnoudb.js"></script> <!-- Para las versiones anteriores --> <!--[if lt IE 9]> <script src=" <![endif]--> </head> <body> <div class="container"> <section class="tabblue"> <ul class="tabs blue"> Lenguajes Interpretados en el Cliente 45

46 <li> <input name="tabs blue" id="tab1" checked="" type="radio"> <label for="tab1">datos del alumno</label> <div id="tab-content1" class="tab-content"> <p> Ingresa los siguientes datos para completar tu registro. </p> <form name="frmmat" id="pais"> <!-- <form name="register" action=""> --> <span class="tabaddon"><i class="fa fa-user fa-2x"></i></span> <input type="text" name="txtname" id="txtname" required="required" placeholder="(su nombre)" class="field" /> <span class="tabaddon"><i class="fa fa-envelope fa-2x"></i></span> <input type="text" name="txtlastname" id="txtlastname" required="required" placeholder="(su apellido)" class="field" /> <span class="tabaddon"><i class="fa fa-lock fa-2x"></i></span> <input type="number" name="txtage" id="txtage" required="required" placeholder="(su edad)" class="field" /> <div class="accounttype"> <p>género:</p> <input type="radio" value="masculino" id="radioone" name="chkgender" checked="checked" /> <label for="radioone" class="radio" chec>masculino</label> <input type="radio" value="femenino" id="radiotwo" name="chkgender" /> <label for="radiotwo" class="radio">femenino</label> </div> <span class="tabaddon"><i class="fa fa-degree fa-2x"></i></span> <select name="seldegree" id="seldegree"> <option disabled="" selected="" value="0">(seleccione una carrera)</option> <option value="ingeniería en Computación">Ingeniería en Computación</option> <option value="ingeniería en Mecatrónica">Ingeniería en Mecatrónica</option> <option value="ingeniería Industrial">Ingeniería Industrial</option> <option value="ingeniería Biomédica">Ingeniería Biomédica</option> <option value="ingeniería en Telecomunicaciones">Ingeniería en Telecomunicaciones</option> <option value="ingeniería Aeronáutica">Ingeniería Aeronáutica</option> <option value="licenciatura en Mercadotecnia">Licenciatura en Mercadotecnia</option> <option value="licenciatura en Idiomas">Licenciatura en Idiomas</option> <option value="licenciatura de Diseño Gráfico">Licenciatura de Diseño Gráfico</option> <option value="licenciatura en Comunicación">Licenciatura en Comunicación</option> <option value="licenciatura en Administración de Empresas">Licenciatura en Administración de Empresas</option> <option value="técnico en Computación">Técnico en Computación</option> <option value="técnico en Multimedia">Técnico en Multimedia</option> <option value="técnico en Ortesis y Prótesis">Técnico en Ortesis y Prótesis</option> </select> <div class="btn"> <input type="button" name="btnsend" id="btnsend" value="matricular" /> </div> Lenguajes Interpretados en el Cliente 46

47 </form> </div> </li> </ul> </section> </div> <!-- Formulario original --> <!-- <form name="frmmat" id="pais"> <fieldset id="wrapper"> <legend> <span>datos del alumno:</span> </legend> <label for="txtname">nombre:</label> <input type="text" name="txtname" id="txtname" maxlength="30" value="" placeholder="(nombre)" /><br /> <label for="txtlastname">apellido:</label> <input type="text" name="txtlastname" id="txtlastname" maxlength="30" value="" placeholder="(apellido)" /><br /> <label for="txtage">edad:</label> <input type="number" name="txtage" id="txtage" maxlength="2" value="" placeholder="(su edad)" /><br /> <label for="txtdegree">carrera:</label> <select name="txtdegree" id="txtdegree"> <option value="ingeniería en Computación">Ingeniería en Computación</option> <option value="ingeniería en Mecatrónica">Ingeniería en Mecatrónica</option> <option value="ingeniería Industrial">Ingeniería Industrial</option> <option value="ingeniería Biomédica">Ingeniería Biomédica</option> <option value="ingeniería en Telocomunicaciones">Ingeniería en Telocomunicaciones</option> <option value="ingeniería Aeronáutica">Ingeniería Aeronáutica</option> <option value="licenciatura en Mercadotecnia">Licenciatura en Mercadotecnia</option> <option value="licenciatura en Idiomas">Licenciatura en Idiomas</option> <option value="licenciatura de Diseño Gráfico">Licenciatura de Diseño Gráfico</option> <option value="licenciatura en Comunicación">Licenciatura en Comunicación</option> <option value="licenciatura en Administración de Empresas">Licenciatura en Administración de Empresas</option> <option value="técnico en Computación">Técnico en Computación</option> <option value="técnico en Multimedia">Técnico en Multimedia</option> <option value="técnico en Ortesis y Prótesis">Técnico en Ortesis y Prótesis</option> </select> <input type="button" name="btnsend" id="btnsend" value="matricular" class="css3dbutton" /> </fieldset> </form> --> </body> </html> Guión 2: alumnoudb.js //Registrar evento click al presionar el botón de envío function iniciar(){ var btnenviar = document.getelementbyid("btnsend"); //Al producirse un click sobre el botón de envío //invocar los métodos del objeto carro que mostrarán //los valores ingresados en el formulario if(btnenviar.addeventlistener){ btnenviar.addeventlistener("click", function(){ var chkvalue, selvalue, nuevoalumno; Lenguajes Interpretados en el Cliente 47

48 var radiofield = document.frmmat.elements["chkgender"]; for(var i=0; i<radiofield.length; i++){ if(radiofield[i].checked){ chkvalue = radiofield[i].value; selvalue = document.frmmat.seldegree.options[frmmat.seldegree.selectedindex].value; nuevoalumno = new alumnoudb(document.frmmat.txtname.value, document.frmmat.txtlastname.value, document.frmmat.txtage.value, chkvalue, selvalue); nuevoalumno.matricular(); nuevoalumno.imprimir();, false); else{ btnenviar.attachevent("onclik", function(){ var chkvalue, nuevoalumno; var radiofield = document.frmmat.elements["chkgender"]; for(var i=0; i<radiofield.length; i++){ if(radiofield[i].checked){ chkvalue = radiofield[i].value; selvalue = document.frmmat.seldegree.options[frmmat.seldegree.selectedindex].value; nuevoalumno = new alumnoudb(document.frmmat.txtname.value, document.frmmat.txtlastname.value, document.frmmat.txtage.value, chkvalue, selvalue); nuevoalumno.matricular(); nuevoalumno.imprimir(); ); //Definiendo la clase alumnoudb haciendo uso de sintaxis de función function alumnoudb(nombre, apellido, edad, genero, carrera){ //Propiedades de la clase this.nombre = nombre; this.apellido = apellido; this.edad = edad; this.genero = genero; this.carrera = carrera; this.numcarnet = null; //Métodos de la clase this.matricular = function(){ var fecha = new Date(); var year = fecha.getfullyear(); var day = fecha.getdate(); var sec = fecha.getseconds(); this.numcarnet = this.nombre.substring(0,1) + this.apellido.substring(0,1) + this.formato(sec) + this.formato(day) + year; this.imprimir = function(){ document.write("<!doctype html>\n"); document.write("<html lang=\"es\">\n"); document.write("<head>\n\t"); document.write("<title>alumno matriculado</title>\n"); document.write("<meta charset=\"utf-8\" />"); document.write("<link rel=\"stylesheet\" href=\"css/infoalumno.css\"/>\n"); document.write("</head>\n"); document.write("<body>\n"); document.write("<table class=\"carinfo\"><tr>\n"); document.write("<th colspan=\"2\">datos del alumno</th>\n"); document.write("<tr><td>carnet: </td>\n"); Lenguajes Interpretados en el Cliente 48

49 document.write("<td>" + this.numcarnet + "</td></tr>\n"); document.write("<tr><td>nombre: </td>\n"); document.write("<td>" + this.nombre + " " + this.apellido + "</td></tr>\n"); document.write("<tr><td>edad: </td>\n"); document.write("<td>" + this.edad + "</td></tr>\n"); document.write("<tr><td>género: </td>\n"); document.write("<td>" + this.genero + "</td></tr>\n"); document.write("<tr><td>carrera: </td>\n"); document.write("<td>" + this.carrera + "</td></tr>\n"); document.write("</tr></table>\n"); document.write("</head>\n"); document.write("</html>\n"); this.formato = function(valor){ if(valor<10) valor = "0" + valor; return valor; //Asociando función que manejará el evento load al cargar la página if(window.addeventlistener){ window.addeventlistener("load", iniciar, false); else{ window.attachevent("onload", iniciar); Guión 3: url( * { margin: 0; padding: 0; -moz-box-sizing: border-box; -webkit-box-sizing: border-box; box-sizing: border-box; body { background: #FFFFFF; color: #fff; font-family: 'Lato',Arial,sans-serif; text-align: left; header { border-bottom: 1px solid #EDEFF0; color: #009EE0; font-family: 'Lato',Arial,sans-serif; height: 100px; line-height: 100px; margin: 0 auto; max-width: 100%; position: relative; text-align: center; h1 { color:#2d2b2c; Lenguajes Interpretados en el Cliente 49

50 font-size: 2.625em; font-weight: 300; line-height: 1.3; line-height:100px; margin: 0; small { bottom: 25px; color: #EF0C72; font-size: 18px; font-weight: bold; position: relative;.container { float: left; height: 481px; padding: 20px 0; width: 100%; section { position: relative; height: 442px; margin-left: 50%; left: -197px; width: { font-family: 'FontAwesome'; src: url('../fonts/fontawesome-webfont.eot?v=4.0.3'); src: url('../fonts/fontawesome-webfont.eot?#iefix&v=4.0.3') format('embedded-opentype'), url('../fonts/fontawesome-webfont.woff?v=4.0.3') format('woff'), url('../fonts/fontawesome-webfont.ttf?v=4.0.3') format('truetype'), url('../fonts/fontawesome-webfont.svg?v=4.0.3#fontawesomeregular') format('svg'); font-weight: normal; font-style: normal; /* Anulando estilos de campos de formulario cuando se obtenga el foco */ :focus {outline:none.fa { display: inline-block; font-family: FontAwesome; font-style: normal; font-weight: normal; line-height: 1; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; cursor:pointer;.fa:hover{ -moz-transform:scale(1.2); /* Firefox */ -ms-transform:scale(1.2); /* IE 9 */ -o-transform:scale(1.2); /* Opera */ -webkit-transform:scale(1.2); /* Safari and Chrome */ transform:scale(1.2); -ms-transition: 0.5s; -moz-transition: 0.5s; Lenguajes Interpretados en el Cliente 50

51 -o-transition: 0.5s; -webkit-transition: 0.5s; transition: 0.5s; /* makes the font 33% larger relative to the icon container */.fa-2x { font-size: 20px; line-height:40px; /* Font Awesome uses the Unicode Private Use Area (PUA) to ensure screen readers do not read off random characters that represent icons */.fa-user:before { content: "\f007";.fa-envelope:before { content: "\f007";.fa-lock:before { content: "\f113";.fa-facebook:before { content: "\f02e";.fa-twitter:before { content: "\f099";.fa-degree:before { content: "\f02e";.tabs h1 { font-size: 32px; font-family: 'Roboto'; margin-bottom:15px;.tabs p { font-size: 14px; line-height: 20px; margin-bottom: 8px; /* Each Tab CSS to make Radio button Work*/ /* Blue Color Tab - If you want to used blue tab, just used following css*/ /******************** START ********************/.tabs.blue { float: left; list-style: none; position: relative; text-align: left; width: 394px;.tabs.blue li { float: right; display: block;.tabs.blue input[type="radio"] { Lenguajes Interpretados en el Cliente 51

52 left: -9999px; position: absolute; top: -9999px;.tabs.blue label { display: block; padding: 14px 31px; font-size: 16px; font-weight: normal; cursor: pointer; position: relative; top: 5px; -moz-transition: all 0.2s ease-in-out; -o-transition: all 0.2s ease-in-out; -webkit-transition: all 0.2s ease-in-out; transition: all 0.2s ease-in-out;.tabs.blue.tab-content { z-index: 2; display: none; overflow: hidden; width: 100%; font-size: 17px; line-height: 25px; padding: 15px; position: absolute; top: 53px; left: 0;.tabs.blue [id^="tab"]:checked + label { padding-top: 17px; top: 5px;.tabs.blue [id^="tab"]:checked ~ [id^="tab-content"] { display: block; /* TAB COLOR SCHEME FOR BLUE */.tabblue.tabs label { background: #16b3f5;.tabblue.fa:hover{ color:#009ee0;.tabblue.tabs label:hover { background: #009EE0;.tabblue.tabs.tab-content { background: #009EE0;.tabblue.tabs [id^="tab"]:checked + label { background: #009EE0; Lenguajes Interpretados en el Cliente 52

53 .tabblue.tabs input[type="button"] { background:#3a57af; color: #f0f3f6;.tabblue.tabs input[type="button"]:hover { background:#c4f1fe; color: #060930;.tabblue.tabaddon { color: #16B3F5; /******************** END ********************/ /* TAB Form */.tabs input[type="text"],.tabs input[type="number"],.tabs input[type="date"],.tabs input[type="password"],.tabs input[type=" "],.tabs select { border: medium none; color: #757575; height: 40px; line-height: 40px; margin-bottom: 10px; padding: 10px; width: 89%; /* Estilos para los input type=radio del género */.tabs.accounttype input[type="radio"] { visibility: hidden;.tabs.accounttype label.radio { cursor: pointer; display: inline-block; margin-bottom: 15px; overflow: visible; position: relative; text-indent: 20px;.tabs.accounttype label.radio:before { background: #778899; -ms-border-radius: 100%; -o-border-radius: 100%; -moz-border-radius: 100%; -webkit-border-radius: 100%; border-radius: 10%; content:''; position: absolute; top: 16px; left: 6px; height: 20px; width: 20px;.tabs.accounttype label.radio:after { background: transparent; Lenguajes Interpretados en el Cliente 53

54 border: 3px solid #ffffff; border-top: none; border-right: none; content: ''; height: 0.25em; left: 10px; opacity: 0; position: absolute; -webkit-transform: rotate(-45deg); -moz-transform: rotate(-45deg); -o-transform: rotate(-45deg); -ms-transform: rotate(-45deg); transform: rotate(-45deg); top: 22px; width: 0.5em;.tabs.accounttype input[type="radio"]:checked + label:after { opacity: 1; /* Estilos del elemento select de carrera */.tabs select { float:left; width: 89%;.tabs select.last { margin-right:0px;.tabs.btn { float: left; margin-top: 15px; width: 100%;.tabs.btn em{ font-size:12px;.tabs input[type="button"]{ display:block; float:right; cursor:pointer; border-top: 2px solid #a3ceda; border-left: 2px solid #a3ceda; border-right: 2px solid #4f6267; border-bottom: 2px solid #4f6267; padding: 10px 20px!important; font-size: 14px!important; background-color: #c4f1fe; font-weight: bold; color: #2d525d; text-decoration:none;.tabs input[type="button"]:hover{ -webkit-transition: 0.5s; -moz-transition: 0.5s; -o-transition: 0.5s; -ms-transition: 0.5s; transition: 0.5s; Lenguajes Interpretados en el Cliente 54

55 .tabs h4{ font-style:italic; text-align:center; margin-bottom:10px; font-weight:normal;.tabaddon { background: none repeat scroll 0 0 #FFFFFF; border-right: 1px solid #ebebeb; float: left; height: 40px; text-align: center; width: 40px;.tabs.social { float:left; margin-bottom:10px; width:100%;.tabs.social a { color:#fff; float:left; font-size:14px; padding: 10px 65px 10px 30px; text-decoration:none;.tabs.social.fa{ margin-right:25px;.tabs.social.facebook{ background: none repeat scroll 0 0 #3B5998;.tabs.social.facebook:hover{ background:#3e5fa4; -moz-transition: 0.5s; -ms-transition: 0.5s; -o-transition: 0.5s; -webkit-transition: 0.5s; transition: 0.5s;.tabs.social.twitter{ background: none repeat scroll 0 0 #16B3F5;.tabs.social.twitter:hover{ background:#34bbf4; -moz-transition: 0.5s; -ms-transition: 0.5s; -o-transition: 0.5s; -webkit-transition: 0.5s; transition: 0.5s; Lenguajes Interpretados en el Cliente 55

56 Guión 4: infoalumno.css table.carinfo { border-color: #999999; border-collapse: collapse; border-width: 1px; color:#333333; font-family: verdana,arial,sans-serif; font-size:11px; margin: 26px auto; width: 42%; table.carinfo th { padding: 6px 8px; background: #d5e3e4; background: url( LnczLm9yZy8yMDAwL3N2ZyIgd2lkdGg9IjEwMCUiIGhlaWdodD0iMTAwJSIgdmlld0JveD0iMCAwIDEgMSIgcHJlc2 VydmVBc3BlY3RSYXRpbz0ibm9uZSI+CiAgPGxpbmVhckdyYWRpZW50IGlkPSJncmFkLXVjZ2ctZ2VuZXJhdGVkIiBn cmfkawvudfvuaxrzpsj1c2vyu3bhy2vpblvzzsigede9ijaliib5mt0imcuiihgypsiwjsigeti9ijewmcuipgogic AgPHN0b3Agb2Zmc2V0PSIwJSIgc3RvcC1jb2xvcj0iI2Q1ZTNlNCIgc3RvcC1vcGFjaXR5PSIxIi8+CiAgICA8c3Rv ccbvzmzzzxq9ijqwjsigc3rvcc1jb2xvcj0ii2njzgvlmcigc3rvcc1vcgfjaxr5psixii8+ciagica8c3rvccbvzm ZzZXQ9IjEwMCUiIHN0b3AtY29sb3I9IiNiM2M4Y2MiIHN0b3Atb3BhY2l0eT0iMSIvPgogIDwvbGluZWFyR3JhZGll bnq+ciagphjly3qged0imciget0imcigd2lkdgg9ijeiighlawdodd0imsigzmlsbd0idxjskcnncmfklxvjz2ctz2 VuZXJhdGVkKSIgLz4KPC9zdmc+); background: -moz-linear-gradient(top, #d5e3e4 0%, #ccdee0 40%, #b3c8cc 100%); background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,#d5e3e4), color-stop(40%,#ccdee0), color-stop(100%,#b3c8cc)); background: -webkit-linear-gradient(top, #d5e3e4 0%,#ccdee0 40%,#b3c8cc 100%); background: -o-linear-gradient(top, #d5e3e4 0%,#ccdee0 40%,#b3c8cc 100%); background: -ms-linear-gradient(top, #d5e3e4 0%,#ccdee0 40%,#b3c8cc 100%); background: linear-gradient(to bottom, #d5e3e4 0%,#ccdee0 40%,#b3c8cc 100%); border: 1px solid #999999; table.carinfo td { padding: 6px 8px; background: #ebecda; background: url( LnczLm9yZy8yMDAwL3N2ZyIgd2lkdGg9IjEwMCUiIGhlaWdodD0iMTAwJSIgdmlld0JveD0iMCAwIDEgMSIgcHJlc2 VydmVBc3BlY3RSYXRpbz0ibm9uZSI+CiAgPGxpbmVhckdyYWRpZW50IGlkPSJncmFkLXVjZ2ctZ2VuZXJhdGVkIiBn cmfkawvudfvuaxrzpsj1c2vyu3bhy2vpblvzzsigede9ijaliib5mt0imcuiihgypsiwjsigeti9ijewmcuipgogic AgPHN0b3Agb2Zmc2V0PSIwJSIgc3RvcC1jb2xvcj0iI2ViZWNkYSIgc3RvcC1vcGFjaXR5PSIxIi8+CiAgICA8c3Rv ccbvzmzzzxq9ijqwjsigc3rvcc1jb2xvcj0ii2uwztbjniigc3rvcc1vcgfjaxr5psixii8+ciagica8c3rvccbvzm ZzZXQ9IjEwMCUiIHN0b3AtY29sb3I9IiNjZWNlYjciIHN0b3Atb3BhY2l0eT0iMSIvPgogIDwvbGluZWFyR3JhZGll bnq+ciagphjly3qged0imciget0imcigd2lkdgg9ijeiighlawdodd0imsigzmlsbd0idxjskcnncmfklxvjz2ctz2 VuZXJhdGVkKSIgLz4KPC9zdmc+); background: -moz-linear-gradient(top, #ebecda 0%, #e0e0c6 40%, #ceceb7 100%); background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,#ebecda), color-stop(40%,#e0e0c6), color-stop(100%,#ceceb7)); background: -webkit-linear-gradient(top, #ebecda 0%,#e0e0c6 40%,#ceceb7 100%); background: -o-linear-gradient(top, #ebecda 0%,#e0e0c6 40%,#ceceb7 100%); background: -ms-linear-gradient(top, #ebecda 0%,#e0e0c6 40%,#ceceb7 100%); background: linear-gradient(to bottom, #ebecda 0%,#e0e0c6 40%,#ceceb7 100%); border: 1px solid #999999; table.carinfo th p{ margin:0px; padding:8px; border-top: 1px solid #eefafc; border-bottom:0px; Lenguajes Interpretados en el Cliente 56

57 border-left: 1px solid #eefafc; border-right:0px; table.carinfo td p{ margin:0px; padding:8px; border-top: 1px solid #fcfdec; border-bottom:0px; border-left: 1px solid #fcfdec;; border-right:0px; Resultado en el navegador: V. DISCUSION DE RESULTADOS 1. Realice una aplicación orientada a objetos llamada potencia. Su aplicación debe crear una clase utilizando funciones, en donde las propiedades deben ser tres: la base y la potencia que deben obtener sus valores de dos argumentos enviados a la definición de la función que hará las veces de la clase. Una tercera propiedad para obtener la potencia de elevar la base a la potencia recibida. Su clase debe poseer dos métodos, uno para retornar el cálculo de la potencia con las propiedades de la clase y otro para mostrar mediante un cuadro de alerta el resultado del método del cálculo de la potencia. Debe realizar una interfaz de formulario apropiada para este problema. 2. Siguiendo la metodología de los ejemplos 5 y 6 (función anónima u objeto Object) del procedimiento, cree un objeto llamado miembro que sirva para registrar usuarios en un sitio web. El usuario debe ingresar cierta información básica, como la que se muestra en el formulario de la siguiente imagen y al simular el envío de los datos un script JS debe almacenar la información ingresada en las propiedades del objeto registro que deben coincidir con los nombres o ids de los campos del formulario. Además de esos campos, debe existir una propiedad identificadora en el objeto que deberá crear de la siguiente forma: las iniciales de los dos apellidos (si sólo tiene un apellido duplicar la primera letra del primer apellido) concatenadas con el año Lenguajes Interpretados en el Cliente 57

Creación de una página web accesible sencilla

Creación de una página web accesible sencilla Unidad 2: Las hojas de estilo en cascada Creación de una página web accesible sencilla Objetivos: -Agregar formato a la página creada, a través de una hoja de estilo. Contenidos: -Incorporación de una

Más detalles

Yusef Hassan Montero Francisco Jesús Martín Fernández. Introducción a DOM. Todos los derechos reservados www.nosolousabilidad.com

Yusef Hassan Montero Francisco Jesús Martín Fernández. Introducción a DOM. Todos los derechos reservados www.nosolousabilidad.com Yusef Hassan Montero Francisco Jesús Martín Fernández Introducción a DOM Todos los derechos reservados www.nosolousabilidad.com INTRODUCCIÓN DOM, Document Object Model o Modelo de Objetos de Documento,

Más detalles

CLASS JAVASCRIPT CLASES? OBJETOS PREDEFINIDOS. WINDOW, OBJETO GLOBAL. NUMBER, MATH, DATE, REGEXP, ERROR. (CU01144E)

CLASS JAVASCRIPT CLASES? OBJETOS PREDEFINIDOS. WINDOW, OBJETO GLOBAL. NUMBER, MATH, DATE, REGEXP, ERROR. (CU01144E) APRENDERAPROGRAMAR.COM CLASS JAVASCRIPT CLASES? OBJETOS PREDEFINIDOS. WINDOW, OBJETO GLOBAL. NUMBER, MATH, DATE, REGEXP, ERROR. (CU01144E) Sección: Cursos Categoría: Tutorial básico del programador web:

Más detalles

CSS. Departamento de Lenguajes y Computación Universidad de Almería CSS. Contenidos

CSS. Departamento de Lenguajes y Computación Universidad de Almería CSS. Contenidos Desarrollo de aplicaciones web Manuel Torres Gil mtorres@ual.es Departamento de Lenguajes y Computación Universidad de Almería Desarrollo de aplicaciones web 1. Características y ventajas de 2. Sintaxis

Más detalles

CAPAS O CONTENEDORES EN HTML. ETIQUETAS DIV Y SPAN. EJEMPLOS. MAQUETAR O DAR ESTRUCTURA A LAS PÁGINAS WEB. (CU00726B)

CAPAS O CONTENEDORES EN HTML. ETIQUETAS DIV Y SPAN. EJEMPLOS. MAQUETAR O DAR ESTRUCTURA A LAS PÁGINAS WEB. (CU00726B) APRENDERAPROGRAMAR.COM CAPAS O CONTENEDORES EN HTML. ETIQUETAS DIV Y SPAN. EJEMPLOS. MAQUETAR O DAR ESTRUCTURA A LAS PÁGINAS WEB. (CU00726B) Sección: Cursos Categoría: Tutorial básico del programador web:

Más detalles

ANEXO. Documento de pautas de comunicación y diseño para el desarrollo de trámites en linea.

ANEXO. Documento de pautas de comunicación y diseño para el desarrollo de trámites en linea. ANEXO. Documento de pautas de comunicación y diseño para el desarrollo de trámites en linea. Ministerio de Gobierno y Reforma del Estado Secretaría de Tecnologías para la Gestión Secretaría de Comunicación

Más detalles

Paquete de trabajo 3. Diseño Web del Proyecto REMERI. Manual. Enero 2013

Paquete de trabajo 3. Diseño Web del Proyecto REMERI. Manual. Enero 2013 Paquete de trabajo 3 Diseño Web del Proyecto REMERI Manual Enero 2013 Red Mexicana de Repositorios Institucionales REMERI 2 HOJA EN BLANCO Red Mexicana de Repositorios Institucionales REMERI 3 Paquete

Más detalles

1.1.- Introducción a la Web Vemos una introducción al medio donde se encajan los lenguajes que vamos a tratar: la web.

1.1.- Introducción a la Web Vemos una introducción al medio donde se encajan los lenguajes que vamos a tratar: la web. Sesión 01: Introducción a los lenguajes web COMPUTACION E INFORMATICA WEB DEVELOPPER III Competencias a Conseguir: - Introducción general a la programación web. - Conocer y diferenciar el concepto de páginas

Más detalles

La ventana de Microsoft Excel

La ventana de Microsoft Excel Actividad N 1 Conceptos básicos de Planilla de Cálculo La ventana del Microsoft Excel y sus partes. Movimiento del cursor. Tipos de datos. Metodología de trabajo con planillas. La ventana de Microsoft

Más detalles

Consejos para el correcto armado de HTML para Emails

Consejos para el correcto armado de HTML para Emails Consejos para el correcto armado de HTML para Emails Consejos para el correcto armado de HTML para Emails Cuando desarrollas una campaña de Email Marketing, es fundamental que tu mensaje sea recibido correctamente.

Más detalles

Formularios HTML. Elementos de Programación y Lógica

Formularios HTML. Elementos de Programación y Lógica Formularios HTML Elementos de Programación y Lógica Formularios HTML es un lenguaje de marcado cuyo propósito principal consiste en estructurar los contenidos de los documentos y páginas web. Sin embargo,

Más detalles

Partes del formulario

Partes del formulario Partes del formulario Etiqueta La etiqueta presenta los siguientes atributos: Comando ACTION METHOD ENCTYPE Descripción El valor de este parámetro es la URL del programa o script en el Servidor

Más detalles

Práctica 2: Diseño Web inicial. XHTML avanzado.

Práctica 2: Diseño Web inicial. XHTML avanzado. Grado de Información y Documentación Curso 2011-2012 33864-Informática II Práctica 2: Diseño Web inicial. XHTML avanzado. 1. Introducción y objetivos Introducción En esta práctica el alumno tendrá un tema

Más detalles

XAJAX: una librería de AJAX para PHP (parte 1)

XAJAX: una librería de AJAX para PHP (parte 1) XAJAX: una librería de AJAX para PHP (parte 1) AJAX es el acrónimo de Asynchronous Javascript And XML o Javascript y XML asíncronos dicho en nuestro idioma. Se trata de una combinación de tecnologías que

Más detalles

IFCD0110 CONFECCIÓN Y PUBLICACIÓN DE PÁGINAS WEB. ETSI Minas y Energía - UPM TRANSICIONES. Bernardo Chenlo

IFCD0110 CONFECCIÓN Y PUBLICACIÓN DE PÁGINAS WEB. ETSI Minas y Energía - UPM TRANSICIONES. Bernardo Chenlo IFCD0110 CONFECCIÓN Y PUBLICACIÓN DE PÁGINAS WEB. ETSI Minas y Energía - UPM 1 TRANSICIONES Bernardo Chenlo 2 ANIMANDO CON CSS3 Cómo animar con 3 líneas de CSS en lugar de 60 de JS Transiciones CSS3 Desarrolladas

Más detalles

EXTENSIÓN DE UML PARA APLICACIONES WEB

EXTENSIÓN DE UML PARA APLICACIONES WEB EXTENSIÓN DE UML PARA APLICACIONES WEB 1. Descripción Esta extensión de UML define un conjunto de estereotipos, valores etiquetados y restricciones que nos permiten modelar aplicaciones web. Los estereotipos

Más detalles

Programa por Clase. 8. CSS3 9. Ejercicio Práctico 10. Examen

Programa por Clase. 8. CSS3 9. Ejercicio Práctico 10. Examen Curso CSS Clase 5 Programa por Clase 1. Repaso HTML. Introducción. Reglas CSS internas. 2. Etiquetas básicas de CSS (tipografía, subrayado, etc.) 3. Archivos CSS externos. Colores. Imágenes. 4. Modelo

Más detalles

Para crear formularios se utiliza la barra de herramientas Formulario, que se activa a través del comando Ver barra de herramientas.

Para crear formularios se utiliza la barra de herramientas Formulario, que se activa a través del comando Ver barra de herramientas. Formularios TEMA: FORMULARIOS. 1. INTRODUCCIÓN. 2. CREACIÓN DE FORMULARIOS. 3. INTRODUCIR DATOS EN UN FORMULARIO. 4. MODIFICAR UN FORMULARIO 5. MANERAS DE GUARDAR UN FORMULARIO. 6. IMPRIMIR FORMULARIOS.

Más detalles

Modulo 1 El lenguaje Java

Modulo 1 El lenguaje Java Modulo 1 El lenguaje Java 13 - Codificación en Java Una de las grandes diferencias entre Java y Pascal en cuando a la codificación es que Java se trata de un lenguaje de los llamados case sensitive Esto

Más detalles

Centro de Capacitación en Informática

Centro de Capacitación en Informática Fórmulas y Funciones Las fórmulas constituyen el núcleo de cualquier hoja de cálculo, y por tanto de Excel. Mediante fórmulas, se llevan a cabo todos los cálculos que se necesitan en una hoja de cálculo.

Más detalles

GENERAR DOCUMENTOS HTML USANDO LENGUAJE PHP. EJERCICIO RESUELTO EJEMPLO SENCILLO. (CU00733B)

GENERAR DOCUMENTOS HTML USANDO LENGUAJE PHP. EJERCICIO RESUELTO EJEMPLO SENCILLO. (CU00733B) APRENDERAPROGRAMAR.COM GENERAR DOCUMENTOS HTML USANDO LENGUAJE PHP. EJERCICIO RESUELTO EJEMPLO SENCILLO. (CU00733B) Sección: Cursos Categoría: Tutorial básico del programador web: HTML desde cero Fecha

Más detalles

Lo básico de Javascript. ISIS2603 Departamento de Sistemas y Computación Universidad de los Andes

Lo básico de Javascript. ISIS2603 Departamento de Sistemas y Computación Universidad de los Andes Lo básico de Javascript ISIS2603 Departamento de Sistemas y Computación Universidad de los Andes Javascript Permite extender las capacidades de HTML Se utiliza principalmente del lado del cliente para

Más detalles

HTML. HTML (HyperText Markup Language) Creado en 1989 por el físico nuclear TIM BERNERS- LEE

HTML. HTML (HyperText Markup Language) Creado en 1989 por el físico nuclear TIM BERNERS- LEE HTML HTML (HyperText Markup Language) Creado en 1989 por el físico nuclear TIM BERNERS- LEE Se elaboró un protocolo para soportar e envío de información por la red. HTTP (Hyper Text Transfer Protocol)

Más detalles

RECUPERAR DATOS DE UN FORMULARIO HTML USANDO PHP. USO DE $_GET. EJEMPLOS Y EJERCICIOS RESUELTOS. (CU00833B)

RECUPERAR DATOS DE UN FORMULARIO HTML USANDO PHP. USO DE $_GET. EJEMPLOS Y EJERCICIOS RESUELTOS. (CU00833B) APRENDERAPROGRAMAR.COM RECUPERAR DATOS DE UN FORMULARIO HTML USANDO PHP. USO DE $_GET. EJEMPLOS Y EJERCICIOS RESUELTOS. (CU00833B) Sección: Cursos Categoría: Tutorial básico del programador web: PHP desde

Más detalles

UNIVERSIDAD DE EL SALVADOR FACULTAD MULTIDISCIPLINARIA DE OCCIDENTE TEMA: XHTML CATEDRA: INTRODUCCION A LA PROGRAMACION EN INTERNET

UNIVERSIDAD DE EL SALVADOR FACULTAD MULTIDISCIPLINARIA DE OCCIDENTE TEMA: XHTML CATEDRA: INTRODUCCION A LA PROGRAMACION EN INTERNET UNIVERSIDAD DE EL SALVADOR FACULTAD MULTIDISCIPLINARIA DE OCCIDENTE TEMA: XHTML CATEDRA: INTRODUCCION A LA PROGRAMACION EN INTERNET DOCENTE: Ing. CARLOS ARTURO RUANO. INSTRUCTOR: Tec. DANIEL EDENILSON

Más detalles

JavaScript como Orientación a Objetos

JavaScript como Orientación a Objetos Gustavo Lacoste (gustavo@lacosox.org) October 2012 Resumen El objetivo de las siguientes notas es generar una estructura en JavaScript que nos permita reutilizar de manera limpia las funciones creadas

Más detalles

CSS. Cascading Style Sheets (Hojas de estilo en cascada)

CSS. Cascading Style Sheets (Hojas de estilo en cascada) 1 CSS Cascading Style Sheets (Hojas de estilo en cascada) INTRODUCCIÓN Las Hojas de estilo son un conjunto de reglas de estilo definidas por el programador sobre elementos HTML, que definen la apariencia

Más detalles

JavaScript Básico. Ejemplo. Arreglos en JavaScript Creación de Arreglos. Asignación de valores. var miarray = new Array() var miarray = new Array(10)

JavaScript Básico. Ejemplo. Arreglos en JavaScript Creación de Arreglos. Asignación de valores. var miarray = new Array() var miarray = new Array(10) 1 JavaScript (III) JavaScript Básico Arreglos en JavaScript Creación de Arreglos var miarray = new Array() var miarray = new Array(10) Asignación de valores. miarray[0] = 1 miarray[1] = 0.5 miarray[2]

Más detalles

Yusef Hassan Montero Francisco Jesús Martín Fernández. Referencia CSS. Todos los derechos reservados www.nosolousabilidad.com

Yusef Hassan Montero Francisco Jesús Martín Fernández. Referencia CSS. Todos los derechos reservados www.nosolousabilidad.com Yusef Hassan Montero Francisco Jesús Martín Fernández Referencia CSS Todos los derechos reservados www.nosolousabilidad.com Introducción Este documento tiene por objetivo servir de material de apoyo y

Más detalles

7. Definición de un estilo en función del contexto.

7. Definición de un estilo en función del contexto. 7. Definición de un estilo en función del contexto. Este otro recurso que provee las CSS es la definición de un estilo para una marca HTML siempre y cuando la misma esté contenida por otra marca determinada.

Más detalles

Plantilla de texto plano

Plantilla de texto plano Plantilla de texto plano Esta es la plantilla seleccionada por defecto al crear una nueva página. Título: Es el título que aparecerá identificando a la página, así como en la cabecera del documento en

Más detalles

Tema 6 Parte III. Frameworks web para dispositivos móviles

Tema 6 Parte III. Frameworks web para dispositivos móviles Tema 6 Parte III Frameworks web para dispositivos móviles 2 1 Introducción Frameworks web para dispositivos móviles Frameworks web para móviles Frameworks web para móviles 3 Nos permiten desarrollar un

Más detalles

Ingeniería de Sistemas

Ingeniería de Sistemas Ingeniería de Sistemas Desarrollo y Servicios Web Sesión 7 Fernando Barraza A. fbarraza@puj.edu.co Sesión 7 Objetivo: Conocer el lenguaje de programación JavaScript, su estructura y aplicación en el desarrollo

Más detalles

Índice. Introducción. Página 2 Empecemos con un ejemplo. Página 3 Crea tu site: Página 3

Índice. Introducción. Página 2 Empecemos con un ejemplo. Página 3 Crea tu site: Página 3 Índice. Introducción. Página 2 Empecemos con un ejemplo. Página 3 Crea tu site: Página 3 Anexo. Guía para desarrollo de programas en HTML y JavaScript. 1. Introducción. En este anexo vamos a escribir un

Más detalles

Clases y objetos en JavaScript

Clases y objetos en JavaScript Clases y objetos en JavaScript Sergio Luján Mora Departamento de Lenguajes y Sistemas Informáticos JavaScript Nombre original: Mocha LiveScript (1995) Netscape 2.0B3 (diciembre 1995) Lenguaje más estándar

Más detalles

Tutorial Servicios Web

Tutorial Servicios Web Tutorial Servicios Web 1. Servicios Web con REST Como ya hemos usado SOAP para WebService, podemos afirmar que es bien fácil de diseñar, pero algo complicado de consumir: se necesita toda una API para

Más detalles

MAQUETACIÓN CON CSS. Elementos principales. Diseño fijo, líquido, elástico

MAQUETACIÓN CON CSS. Elementos principales. Diseño fijo, líquido, elástico MAQUETACIÓN CON CSS Elementos principales Para maquetar una página web y crear su estructura visual (layout) hay que dividir la página en bloques. La estructura de una página web tendrá una serie de áreas

Más detalles

Mi primera web... Pues bien una vez que tengamos el documento abierto, podemos empezar a trabajar de dos formas:

Mi primera web... Pues bien una vez que tengamos el documento abierto, podemos empezar a trabajar de dos formas: Mi primera web... El ejemplo que utilizaremos para este tutorial, es la misma página web de los tutoriales. Puede descargar los archivos desde aquí. Para la creación de las imagenes he utilizado Fireworks

Más detalles

Desarrollo de sitios Web con HTML5, CSS3, jquery y Responsive Web Design

Desarrollo de sitios Web con HTML5, CSS3, jquery y Responsive Web Design Desarrollo de sitios Web con HTML5, CSS3, jquery y Responsive Web Design Nivel básico. Duración: 20 horas. Lección 1. Creando tu primera página Web en HTML5. Qué es HTML5 y CSS3? Términos comunes utilizados

Más detalles

UNIVERSIDAD DON BOSCO FACULTAD DE ESTUDIOS TECNOLÓGICOS COMPUTACIÓN

UNIVERSIDAD DON BOSCO FACULTAD DE ESTUDIOS TECNOLÓGICOS COMPUTACIÓN UNIVERSIDAD DON BOSCO FACULTAD DE ESTUDIOS TECNOLÓGICOS COMPUTACIÓN CICLO: 02/2015 GUIA DE LABORATORIO #3 Nombre de la Practica: Estructuras de control: sentencias repetitivas y matrices Lugar de Ejecución:

Más detalles

Personalización plantilla Kamera. Aisha (Elai the Blogger) para El perro de papel www.elperrodepapel.com

Personalización plantilla Kamera. Aisha (Elai the Blogger) para El perro de papel www.elperrodepapel.com Personalización plantilla Kamera Aisha (Elai the Blogger) para El perro de papel www.elperrodepapel.com PERSONALIZACIÓN PLANTILLA KAMERA Otra plantilla pensada para blogs donde la fotografía es uno de

Más detalles

EJERCICIOS HTML BÁSICOS

EJERCICIOS HTML BÁSICOS EJERCICIOS HTML BÁSICOS Ejercicio 1 Crear un documento HTML desde cero Crea la estructura de carpetas del sitio (carpeta raíz, carpeta de imágenes y de scripts). Dentro de la carpeta de scripts crea un

Más detalles

Cursito 28: Curso de HTML Parte 4

Cursito 28: Curso de HTML Parte 4 Por Roxana Bassi rox@roxanabassi.com.ar / http://www.roxanabassi.com.ar Publicado en la sección los cuadernos de Internet World en la revista Internet World Latinoamérica en el período 1995-1999 Cursito

Más detalles

Elementos de Microsoft Word

Elementos de Microsoft Word Contenido 1. Distintas formas de iniciar Word 2007... 2 2. Ayuda de Word... 2 3. Las barras de herramientas... 3 4. Funcionamiento de las pestañas. Cómo funcionan?... 4 5. Personalizar barra de acceso

Más detalles

FUNDACION EDUCATIVA OBRERA FUNEDO TECNICO EN SECRETARIADO EJECUTIVO SISTEMATIZADO

FUNDACION EDUCATIVA OBRERA FUNEDO TECNICO EN SECRETARIADO EJECUTIVO SISTEMATIZADO LOS FORMULARIOS Los formularios sirven para definir pantallas generalmente para editar los registros de una tabla o consulta. Veremos cómo crear un formulario, manejarlo para la edición de registros y

Más detalles

PHP: Interacción con HTML

PHP: Interacción con HTML Francisco J. Martín Mateos Carmen Graciani Diaz Dpto. Ciencias de la Computación e Inteligencia Artificial Universidad de Sevilla Variables En algunas ocasiones es necesario saber si una variable tiene

Más detalles

Diseño de páginas web

Diseño de páginas web Diseño de páginas web Formularios Ricardo Esteban Alonso Insertar Formularios (1) Permiten que el visitante envíe información al servidor web, que la procesa y la almacena o bien se nos envía a través

Más detalles

Combinar comentarios y cambios de varios documentos en un documento

Combinar comentarios y cambios de varios documentos en un documento Combinar comentarios y cambios de varios documentos en un documento Si envía un documento a varios revisores para que lo revisen y cada uno de ellos devuelve el documento, puede combinar los documentos

Más detalles

Programa. Conceptos básicos: variables, valores y objetos predefinidos, operadores, etc. etc. Callbacks, eval(), etc.

Programa. Conceptos básicos: variables, valores y objetos predefinidos, operadores, etc. etc. Callbacks, eval(), etc. Programa Programa 1. Introducción. Repaso HTML-CSS. Orientaciones Generales. 2. Javascript: Qué es? Dónde se ejecuta? Cómo se ejecuta? Conceptos básicos: variables, valores y objetos predefinidos, operadores,

Más detalles

ISTP CIDET COMPUTACION E INFORMATICA ARREGLOS EN JAVA

ISTP CIDET COMPUTACION E INFORMATICA ARREGLOS EN JAVA ARREGLOS EN JAVA I I N T R O D U C C I Ó N En las sesiones anteriores, los datos manejados en los programas han sido datos simples (carácter, entero, reales) En un gran número de problemas es necesario

Más detalles

Ingreso al Sistema Administrador

Ingreso al Sistema Administrador Ingreso al Sistema Administrador Para ingresar a esta herramienta se deberá definir un usuario y un password o clave la cual será definida de antemano para usted. Una vez dentro del sistema, usted podrá

Más detalles

MATERIAL 2 EXCEL 2007

MATERIAL 2 EXCEL 2007 INTRODUCCIÓN A EXCEL 2007 MATERIAL 2 EXCEL 2007 Excel 2007 es una planilla de cálculo, un programa que permite manejar datos de diferente tipo, realizar cálculos, hacer gráficos y tablas; una herramienta

Más detalles

Imágenes y objetos IMÁGENES

Imágenes y objetos IMÁGENES IMÁGENES Y OBJETOS Imágenes y objetos 2 IMÁGENES Uno de los elementos más vistosos e importantes de las páginas web. Su introducción puede explicar de manera más fácil y agradable nuestra información al

Más detalles

APLICACIONES PARA INTERNET

APLICACIONES PARA INTERNET CUN APLICACIONES PARA INTERNET GUIA 1 Juan Carlos Saavedra Serrato 2014 1. Consulte Cuantos tipos de Lenguajes de programación web existen y reseñe una característica de cada uno de ellos. Los diferentes

Más detalles

Aprendiendo Yii. Publicación. Armando Arce

Aprendiendo Yii. Publicación. Armando Arce Aprendiendo Yii Publicación Armando Arce 28 de April de 2016 Índice general 1. Primeros pasos con Yii 3 2. Consulta de datos con Yii 11 3. Búsquedas y formularios en Yii 19 4. Inclusión y modificación

Más detalles

Informática I Notas del curso

Informática I Notas del curso EXCEL Objetivo: Identificar la funcionalidad general de Excel, sus herramientas y recursos Excel Objetivo Particular: Conocer los métodos básicos de trabajo de Excel, para el manejo de registros, datos

Más detalles

Instructivo de Microsoft Excel 2003

Instructivo de Microsoft Excel 2003 Instructivo de Microsoft Excel 2003 El presente instructivo corresponde a una guía básica para el manejo del programa y la adquisición de conceptos en relación a este utilitario. Que es Microsoft Excel?

Más detalles

SELECTOR UNIVERSAL. NTH-OF-TYPE Y NTH-LAST- CHILD. COMBINAR SELECTORES. EJEMPLOS Y EJERCICIOS RESUELTOS CSS. (CU01016D)

SELECTOR UNIVERSAL. NTH-OF-TYPE Y NTH-LAST- CHILD. COMBINAR SELECTORES. EJEMPLOS Y EJERCICIOS RESUELTOS CSS. (CU01016D) APRENDERAPROGRAMAR.COM SELECTOR UNIVERSAL. NTH-OF-TYPE Y NTH-LAST- CHILD. COMBINAR SELECTORES. EJEMPLOS Y EJERCICIOS RESUELTOS CSS. (CU01016D) Sección: Cursos Categoría: Tutorial básico del programador

Más detalles

CASO PRÁCTICO DISTRIBUCIÓN DE COSTES

CASO PRÁCTICO DISTRIBUCIÓN DE COSTES CASO PRÁCTICO DISTRIBUCIÓN DE COSTES Nuestra empresa tiene centros de distribución en tres ciudades europeas: Zaragoza, Milán y Burdeos. Hemos solicitado a los responsables de cada uno de los centros que

Más detalles

Tema: Sobrecarga de Operadores.

Tema: Sobrecarga de Operadores. Programación II. Guía 7 1 Facultad: Ingeniería Escuela: Computación Asignatura: Programación II Tema: Sobrecarga de Operadores. Objetivos Describir como redefinir (sobrecargar) operadores para que funcionen

Más detalles

Tablas en HTML. Tipos de celdas. Ing. Tomás Urbina Programación Web y Desarrollo de la Plataforma Web

Tablas en HTML. Tipos de celdas. Ing. Tomás Urbina Programación Web y Desarrollo de la Plataforma Web Tablas en HTML Ing. Tomás Urbina Programación Web y Desarrollo de la Plataforma Web Una tabla HTML puede ser considerada de manera simple como un grupo de filas donde cada una de ellas contiene un grupo

Más detalles

Capítulo 3 Estilo para un documento HTML: CSS

Capítulo 3 Estilo para un documento HTML: CSS Capítulo 3 Estilo para un documento HTML: CSS.3.0 Qué es el estilo?!"#$ "!$ &'!$!($ ) *+ " *, -.,#/-..3.1 Propiedades y valores 0 )" & + 1& &1& 2 " '" Medidas: 3 + 14 "56 1'#/ 1/5-7 3 1 1 + 1' Colores:

Más detalles

Introducción a Visual Studio.Net

Introducción a Visual Studio.Net Introducción a Visual Studio.Net Visual Studio es un conjunto completo de herramientas de desarrollo para la generación de aplicaciones Web ASP.NET, Servicios Web XML, aplicaciones de escritorio y aplicaciones

Más detalles

Para ingresar a la aplicación Microsoft PowerPoint 97, los pasos que se deben seguir pueden ser los siguientes:

Para ingresar a la aplicación Microsoft PowerPoint 97, los pasos que se deben seguir pueden ser los siguientes: Descripción del ambiente de trabajo Entrar y salir de la aplicación Para ingresar a la aplicación Microsoft PowerPoint 97, los pasos que se deben seguir pueden ser los siguientes: A través del botón :

Más detalles

Instructivo Asesoría Básica Comunidad Virtual SharePoint 2010

Instructivo Asesoría Básica Comunidad Virtual SharePoint 2010 Instructivo Asesoría Básica Comunidad Virtual SharePoint 2010 CONTENIDO 1. Qué es? 2. Cómo crear y acceder a la Comunidad Virtual en Microsoft SharePoint 2010? Ejemplo. 3. Qué tengo en la página de inicio

Más detalles

Diseño de páginas web 2011

Diseño de páginas web 2011 Diseño de páginas web 2011 Al finalizar el curso, el alumno será capaz de planificar y diseñar correctamente desde sencillas páginas web hasta completos sitios web. Para ello, se le proporciona primero

Más detalles

MANUAL DE AYUDA MÓDULO GOTELGEST.NET PREVENTA/AUTOVENTA

MANUAL DE AYUDA MÓDULO GOTELGEST.NET PREVENTA/AUTOVENTA MANUAL DE AYUDA MÓDULO GOTELGEST.NET PREVENTA/AUTOVENTA Fecha última revisión: Septiembre 2014 MANUAL DE AYUDA MÓDULO GOTELGEST.NET PREVENTA/AUTOVENTA MÓDULO GOTELGEST.NET MÓVIL... 3 1. INTRODUCCIÓN A

Más detalles

Javascript parte II: AJAX

Javascript parte II: AJAX Tema 3 Javascript parte II: AJAX Texto http://www.flickr.com/photos/kosmar/62381076 Asynchronous JavaScript and XML. O cómo hacer peticiones al servidor desde Javascript AJAX (Asynchronous JavaScript And

Más detalles

UNIVERSIDAD DON BOSCO FACULTAD DE ESTUDIOS TECNOLÓGICOS COMPUTACIÓN

UNIVERSIDAD DON BOSCO FACULTAD DE ESTUDIOS TECNOLÓGICOS COMPUTACIÓN UNIVERSIDAD DON BOSCO FACULTAD DE ESTUDIOS TECNOLÓGICOS COMPUTACIÓN CICLO: 02/2015 Nombre de la Practica: Lugar de Ejecución: Tiempo Estimado: MATERIA: DOCENTES: GUIA DE LABORATORIO #1 Repaso HTML5 y CSS3.

Más detalles

Widget de catálogos. Manual de Usuario. Versión 2. Madrid 13/08/2015

Widget de catálogos. Manual de Usuario. Versión 2. Madrid 13/08/2015 Widget de catálogos Manual de Usuario Madrid 13/08/2015 Versión 2 Contenidos 1 Introducción... 3 2 Alta de conjuntos de datos en datos.gob.es... 7 3 Descripción del widget... 12 3.1 Widget, versión sencilla...

Más detalles

WinHIPE: edición, compilación y ejecución de programas; y generación de animaciones web. Manual de usuario.

WinHIPE: edición, compilación y ejecución de programas; y generación de animaciones web. Manual de usuario. WinHIPE: edición, compilación y ejecución de programas; y generación de animaciones web. Manual de usuario. Índice contenido. INTRODUCCIÓN... 1-2 1. ENTORNO DE TRABAJO... 1-2 2. EDICIÓN DE PROGRAMAS...

Más detalles

DREAMWEAVER 2 UNIVERSIDAD TECNOLOGICA DE AGUASCALIENTES

DREAMWEAVER 2 UNIVERSIDAD TECNOLOGICA DE AGUASCALIENTES DREAMWEAVER 2 UNIVERSIDAD TECNOLOGICA DE AGUASCALIENTES Presentación José Alberto Rodríguez Castañeda Universidad Tecnológica de Aguascalientes http://ww.betiux.com.mx betordz@gmail.com Temas. 1) Javascript

Más detalles

JavaScript toma su sintaxis de los lenguajes de programación más conocidos, fundamentalmente C/C++, aunque también algo de Pascal.

JavaScript toma su sintaxis de los lenguajes de programación más conocidos, fundamentalmente C/C++, aunque también algo de Pascal. 1 JavaScript 1.1 Qué es JavaScript? JavaScript es un lenguaje interpretado. Es idóneo para trabajar en Web, ya que son los navegadores que utilizamos los que interpretan (y por tanto ejecutan) los programas

Más detalles

Capítulo 1 Documentos HTML5

Capítulo 1 Documentos HTML5 Capítulo 1 Documentos HTML5 1.1 Componentes básicos HTML5 provee básicamente tres características: estructura, estilo y funcionalidad. Nunca fue declarado oficialmente pero, incluso cuando algunas APIs

Más detalles

Tema: Estilos CSS. Combinadores. Posicionamiento.

Tema: Estilos CSS. Combinadores. Posicionamiento. Diseño Digital V. Guía 5 1 Tema: Estilos CSS. Combinadores. Posicionamiento. Objetivos Contenidos Facultad: Ciencias y Humanidades Escuela: Diseño Gráfico Asignatura: Diseño Digital V A través del desarrollo

Más detalles

Ministerio de Educación, Cultura y Deporte. HTLM5 en la educación. Módulo 11: Maquetación con estilos.

Ministerio de Educación, Cultura y Deporte. HTLM5 en la educación. Módulo 11: Maquetación con estilos. Ministerio de Educación, Cultura y Deporte. HTLM5 en la educación Módulo 11: Maquetación con estilos. Instituto Nacional de Tecnologías Educativas y de Formación del Profesorado 2012 Maquetación con estilos

Más detalles

MACROS Y FORMULARIOS

MACROS Y FORMULARIOS MACROS Y FORMULARIOS Para poder realizar formularios en Excel es necesario ubicar el menú programador Qué hacer si no aparece el menú programador? En algunos equipos no aparece este menú, por lo que es

Más detalles

5.2.1 La Página Principal

5.2.1 La Página Principal 5.2 Las Páginas WEB Una página Web es un documento electrónico escrito en un lenguaje de ordenador llamado HTML, o Hypertext Markup Language (lenguaje de marcación de hipertexto). Como ya hemos dicho,

Más detalles

11. Algunas clases estándar de Java (II)

11. Algunas clases estándar de Java (II) 122 A. García-Beltrán y J.M. Arranz 11. Algunas clases estándar de Java (II) Objetivos: a) Presentar la clase predefinida en Java para trabajar con arrays b) Interpretar el código fuente de una aplicación

Más detalles

INDICE DE CONTENIDOS 1. INTRODUCCIÓN...3 2. CONCEPTOS BÁSICOS DEL CMS XPRESS...5 3. ACCESO AL CMS XPRESS...9 4. PÁGINA INICIAL...

INDICE DE CONTENIDOS 1. INTRODUCCIÓN...3 2. CONCEPTOS BÁSICOS DEL CMS XPRESS...5 3. ACCESO AL CMS XPRESS...9 4. PÁGINA INICIAL... INDICE DE CONTENIDOS 1. INTRODUCCIÓN...3 DEFINICIÓN...3 ELEMENTOS QUE CONSTITUYEN EL SERVICIO...3 TECNOLOGÍA Y OPERATORIA...3 GRÁFICO DE PROCESOS Y FLUJO DE LA INFORMACIÓN...4 2. CONCEPTOS BÁSICOS DEL

Más detalles

DISEÑO ORGANIZACIONAL. Diseño web avanzado con HTML5 y CSS5

DISEÑO ORGANIZACIONAL. Diseño web avanzado con HTML5 y CSS5 DISEÑO ORGANIZACIONAL Diseño web avanzado con HTML5 y CSS5 PRESENTACIÓN Curso de diseño de páginas web en el que se estudian técnicas avanzadas y novedosas gracias a la aplicación de los estándares web

Más detalles

GUIA PROGRAMACIÓN ORIENTADA A OBJETOS

GUIA PROGRAMACIÓN ORIENTADA A OBJETOS GUIA PROGRAMACIÓN ORIENTADA A OBJETOS 1. Por qué la P.O.O? R= A medida que se van desarrollando los lenguajes, se va desarrollando también la posibilidad de resolver problemas más complejos. En la evolución

Más detalles

Un Navegador es un programa que nos conecta a Internet y nos permite organizar nuestro

Un Navegador es un programa que nos conecta a Internet y nos permite organizar nuestro Introducción Un Navegador es un programa que nos conecta a Internet y nos permite organizar nuestro acceso al mundo Web. Cuando queremos entrar a Internet, lo primero que se abre en el ordenador es el

Más detalles

Componente com_weblinks para listados de enlaces web a modo de directorio en Joomla. (CU00442A)

Componente com_weblinks para listados de enlaces web a modo de directorio en Joomla. (CU00442A) aprenderaprogramar.com Componente com_weblinks para listados de enlaces web a modo de directorio en Joomla. (CU00442A) Sección: Cursos Categoría: Curso creación y administración web: Joomla desde cero

Más detalles

Aspectos avanzados de jquery Mobile

Aspectos avanzados de jquery Mobile Aspectos avanzados de jquery Mobile Índice 1 Listados de elementos... 2 1.1 Listados básicos con enlaces...2 1.2 Listados anidados...3 1.3 Listados numerados... 4 1.4 Listados de solo lectura...5 1.5 Listados

Más detalles

MANUAL DE USUARIO DEL SISTEMA PARA EL REDACTOR

MANUAL DE USUARIO DEL SISTEMA PARA EL REDACTOR MANUAL DE USUARIO DEL SISTEMA PARA EL REDACTOR Conceptos Básicos. Drupal es un sistema de gestión de contenido que permite manejar artículos, fotos, archivos, etc. Es un sistema dinámico que administra

Más detalles

Desarrollo de Aplicaciones para Internet I. Unidad III - CSS Profesor: M.C. Martín Olguín

Desarrollo de Aplicaciones para Internet I. Unidad III - CSS Profesor: M.C. Martín Olguín Desarrollo de Aplicaciones para Internet I Unidad III - CSS Profesor: M.C. Martín Olguín Cascading Style Sheets (CSS) Aunque el HTML desde sus orígenes privilegia el contenido sobre la apariencia, esta

Más detalles

LABORATORIO Nº 2 GUÍA PARA REALIZAR FORMULAS EN EXCEL

LABORATORIO Nº 2 GUÍA PARA REALIZAR FORMULAS EN EXCEL OBJETIVO Mejorar el nivel de comprensión y el manejo de las destrezas del estudiante para utilizar formulas en Microsoft Excel 2010. 1) DEFINICIÓN Una fórmula de Excel es un código especial que introducimos

Más detalles

SESIÓN 6 INTRODUCCIÓN A WORD.

SESIÓN 6 INTRODUCCIÓN A WORD. SESIÓN 6 INTRODUCCIÓN A WORD. I. CONTENIDOS: 1. La pantalla de Word. 2. Partes de la pantalla de Word. 3. Funcionamiento de los menús. 4. Distintas formas de ver un documento. 5. Trabajar con varios documentos

Más detalles

UNIVERSIDAD DON BOSCO FACULTAD DE ESTUDIOS TECNOLOGICOS ESCUELA DE COMPUTACION

UNIVERSIDAD DON BOSCO FACULTAD DE ESTUDIOS TECNOLOGICOS ESCUELA DE COMPUTACION CICLO 01-2016 UNIVERSIDAD DON BOSCO FACULTAD DE ESTUDIOS TECNOLOGICOS ESCUELA DE COMPUTACION GUIA DE LABORATORIO Nº 10 Nombre de la práctica: Maquetación de páginas web Lugar de ejecución: Laboratorio

Más detalles

1 OBJETOS, DOM, JSON

1 OBJETOS, DOM, JSON OBJETOS, DOM, JSON 1 2 Objetos http://www.w3schools.com/js/js_obj_intro.asp Se delimitan con llaves. Contienen propiedades. Las propiedades del objeto: pares nombre: valor, separados por comas. var alumno

Más detalles

Figura 4.1 Clasificación de los lenguajes de bases de datos

Figura 4.1 Clasificación de los lenguajes de bases de datos 1 Colección de Tesis Digitales Universidad de las Américas Puebla Romero Martínez, Modesto Este capítulo describen los distintos lenguajes para bases de datos, la forma en que se puede escribir un lenguaje

Más detalles

2011 - Copyright Arsys Internet S.L. Campañas Online Manual de Usuario

2011 - Copyright Arsys Internet S.L. Campañas Online Manual de Usuario Campañas Online Manual de Usuario Índice 1 Introducción 2 Acceso a Campañas Online 2.1 Acceso a través del Panel de Control de arsys.es 2.2 Acceso a través de la URL https://www.marketingpanel.es 3 Inicio

Más detalles

Arquitectura de Tecnologías Web Por César Bustamante Gutiérrez. Módulo II: Tecnologias del lado del Cliente Tema 1: HTML5. www.librosdigitales.

Arquitectura de Tecnologías Web Por César Bustamante Gutiérrez. Módulo II: Tecnologias del lado del Cliente Tema 1: HTML5. www.librosdigitales. 1 Que es CSS3? El CSS sirve para definir la estética de un sitio web en un documento externo y eso mismo permite que modificando ese documento (la hoja CSS) podamos cambiar la estética entera de un sitio

Más detalles

Clase Nº 9 OPERADOR PC. P á g i n a 1 HOJA DE CALCULO MICROSOFT EXCEL

Clase Nº 9 OPERADOR PC. P á g i n a 1 HOJA DE CALCULO MICROSOFT EXCEL P á g i n a 1 Clase Nº 9 HOJA DE CALCULO MICROSOFT EXCEL Para acceder a este programa se debe hacer clic en el botón INICIO, luego en PROGRAMAS, luego en MICROSOFT OFFICE y finalmente en MICROSOFT EXCEL.

Más detalles

UNIDAD EJECUTORA DE CONSERVACION VIAL MANUAL DEL USUARIO DEL SISTEMA INTEGRAL DE CONTROL DE PROYECTOS

UNIDAD EJECUTORA DE CONSERVACION VIAL MANUAL DEL USUARIO DEL SISTEMA INTEGRAL DE CONTROL DE PROYECTOS UNIDAD EJECUTORA DE CONSERVACION VIAL MANUAL DEL USUARIO DEL SISTEMA INTEGRAL DE CONTROL DE PROYECTOS Guatemala, Julio de 2008 Índice Gestión de equipos...4 Programación física...5 Trabajos por Administración...6

Más detalles

UNIVERSIDAD DON BOSCO FACULTAD DE ESTUDIOS TECNOLÓGICOS ESCUELA DE COMPUTACIÓN

UNIVERSIDAD DON BOSCO FACULTAD DE ESTUDIOS TECNOLÓGICOS ESCUELA DE COMPUTACIÓN UNIVERSIDAD DON BOSCO FACULTAD DE ESTUDIOS TECNOLÓGICOS ESCUELA DE COMPUTACIÓN CICLO: 02/2015 GUIA DE LABORATORIO #11 Nombre de la Práctica: Administración de cursos haciendo uso de Moodle Lugar de Ejecución:

Más detalles

Carlos Roberto Jaimez González. Programación de Web Dinámico

Carlos Roberto Jaimez González. Programación de Web Dinámico Carlos Roberto Jaimez González Programación de Web Dinámico Carlos Roberto Jaimez González Programación de Web Dinámico Esta investigación fue dictaminada por pares académicos Clasificación Dewey: 005.13

Más detalles

HTML dinámico: Javascript

HTML dinámico: Javascript Javascript Departamento de Lenguajes escuela técnica superior de ingeniería informática Grupo de Ingeniería a del Software Noviembre 2006 Versión original: Amador Durán y David Benavides (octubre 2005)

Más detalles

TEMA 9 CREACIÓN DE PÁGINAS WEB

TEMA 9 CREACIÓN DE PÁGINAS WEB TEMA 9 CREACIÓN DE PÁGINAS WEB OBJETIVOS Conocer las páginas web y sus elementos. Insertar tablas, capas, enlaces en las páginas web. Crear páginas web con NVU. Crear un sitio web. Configurar un sitio

Más detalles