Prototype es un framework escrito en JavaScript que se orienta al desarrollo sencillo y dinámico de aplicaciones web. Es una herramienta que implementa las técnicas AJAX y su potencial es aprovechado al máximo cuando se desarrolla con Ruby On Rails.
Prototype | ||
---|---|---|
Información general | ||
Tipo de programa | Biblioteca javascript | |
Desarrollador | Prototype Core Team | |
Licencia | MIT | |
Información técnica | ||
Programado en | Javascript | |
Versiones | ||
Última versión estable | 1.7.1 ( 22 de septiembre de 2015 (9 años, 3 meses y 27 días)) | |
Enlaces | ||
Sitio web oficial
Repositorio de código
| ||
Con la Web 2.0 las técnicas de desarrollo de páginas web necesitaban dar un gran salto. Con esto en mente nació la técnica AJAX, que gracias a Prototype permite el desarrollo ágil y sencillo de páginas Web, esto en relación con el desarrollador, y provee al cliente una manera más rápida de acceder al servicio que solicita. Prototype es un Framework basado en JavaScript orientado a proporcionar al desarrollador de técnicas AJAX listas para ser usadas. El potencial de Prototype es aprovechado al máximo si se desarrolla con Ruby On Rails, esto no quiere decir que no se puede usar desde otro lenguaje, solamente que demandara un "mayor esfuerzo" en el desarrollo.
Antes de comenzar a desarrollar Prototype, es necesario presentar el concepto AJAX, debido a que Prototype emplea AJAX.
AJAX proviene de Ashyncronous JavaScript And XML. En pocas palabras AJAX es una técnica de desarrollo Web que incorpora varias tecnologías, como son el JavaScript y XML, consiguiendo de esta manera una forma de navegar rápida, ágil y dinámica.
evento
-Inicializada -Iniciada -En proceso de retornar la información -Operación completada
(En Internet Explorer 7, se implementa como JavaScript nativo)
Para obtener más información consulte la página sobre AJAX.
Prototype es un framework desarrollado en JavaScript por Sam Stephenson para el desarrollo sencillo y dinámico de páginas Web. Prototype nos simplifica gran parte del trabajo cuando se pretende desarrollar páginas altamente interactivas.
Para comenzar a trabajar con Prototype es necesario obtener el framework, para ello deben dirigirse al sitio http://www.prototypejs.org/ y descargar prototype.js y para usarlo deben hacer lo siguiente:
<script type="text/JavaScript" src="path/to/prototype.js"></script>
si emplea Ruby On Rails no es necesario descargar prototype.js, la biblioteca viene incluida. Para hacer uso de ello simplemente se lo incluye dentro de las etiquetas <head>:
<%= javascript_include_tag 'prototype' %>
Ahora que ya lo tenemos instalado es hora de empezar a usar Prototype. Prototype dispone de funciones sencillas para proporcionar ayuda a la hora de escribir los scripts.
La Función $() es bastante útil, al principio puede parecer un poco abstracta, esta función es un atajo a la función del DOM document.getElementById(), Un ejemplo para explicarlo.
<button onclick = "Hacer();" Id = "boton"> clic </button>
<script>
function Hacer(){var elemento = $('#boton');elemento.innerHTML = 'Saludos!'; elemento.style.color = 'blue';}
</script>
Esta etiqueta DIV donde quieras que aparezca el elemento:
<div id="boton"> </div>
La función $(), puede recibir el id del elemento, o puede recibir el propio elemento, y si recibe más de un elemento devuelve un vector de elementos.
Esta función convierte cualquier parámetro en un objeto array, pero el objeto vector de Prototype no es exactamente como el vector de javascript, ya que posee una extensión llamada Enumerable, la cual es una copia del lenguaje de programación Ruby, dándole mucha más versatilidad a JavaScript. Un Ejemplo simple.
<input type='button' value="click" onclick="Arreglo()">
<script>
function Arreglo()
{var Lista=document.getElementsByTagName('div');
var Arreglo = $A(Lista);
Arreglo.each(function(el, indice){
el.innerHTML = indice + ':' + 'divider' + el.id;
el.style.color = 'blue';
})
};
</script>
Convierte un objeto en un hash enumerable
<button onclick="duh();" id="mponce">clic</button>
<script>
function duh()
{var ObjetoUsuario = {id: 1, login: "dponce",
email: "correo_falso@wikipedia.org"};
// convertimos el objeto a un HASH
var el_hash = $H(ObjetoUsuario); $('dponce').innerHTML =
el_hash.toQueryString();
}
</script>
Toma un ID y devuelve el valor de cualquier campo de formulario, por ejemplo, un menú select como este:
<select name="ciudad" id="ciudad">
<option selected="Seleccionar" value="SE">Santiago Del Estero</option>
<option value="AR">Argentina</option>
</select>
<script>
$F('ciudad') // 'SE'
</script>
Recibe una clase como parámetro y devuelve un vector con los elementos que tienen como atributo className de la clase.
<button onclick='duh();' id='padre'>clic</button>
<script>
function duh(){
var arrayNodosfamilia = document.getElementsByClassName('familia');
var Arreglo = $A(arrayNodosfamilia);
Arreglo.each( function(el, indice){
el.innerHTML = indice + ':' + 'divider ' + el.id;
el.style.color = 'blue';
});
}
</script>
Es una mejora de la función document.getElementsByClassName(), recibe como parámetro un selector CSS y devuelve un vector con cada elemento que cumpla con el criterio del selector dado, ejemplo.
<button onclick="duh();" id="padre">clic</button>
<div class="familia" id="hijo"><p>ay caramba!</p></div>
<script>
function duh(){
var arrayNodosFamilia = $$('div#ciudad div.familia');
arrayNodosFamilia.each( function(el, indice){
el.innerHTML = indice + ':' + 'divider ' + el.id;
el.style.color = 'blue';
});
}
</script>
Además podemos escribir nuestro código con menos líneas, por ejemplo
<script>
function duh(){
$$('div#ciudad div.familia').each( function(el, indice){
el.innerHTML = indice + ':' + 'divider ' + el.id;
el.style.color = 'blue';
});
}
</script>
Prototype también añade a la función objeto dos métodos bind y bindAsEventListener. Estos son usados para asociar una función a un objeto particular de modo que la palabra clave apunte a ese objeto. Supongamos que:
var myObject = new Object();
myObject.message = "Hello!";
myObject.eventHandler = function() {
alert(this.message);
}
$("mydiv").onmouseover = myObject.eventHandler;
Tradicionalmente, se conseguiría un error, porque, cuando el evento llama a la función handler, esta se refiere al elemento mydiv, y no a myObject, entonces this.message es indefinido. Se puede solucionar este problema con:
$("mydiv").onmouseover = myObject.eventHandler.bind(myObject);
Ahora funciona bien, porque la palabra clave se limita a myObject. Siguiendo esto, el bindAsEventListener hace lo mismo, aunque pasa el objeto del evento a través de su función de una manera compatible con los distintos navegadores.
Prototype tiene algunos objetos (Element, Insertion, Observer y Position) que permiten distintas formas de manipular el DOM.
La mayor parte de los métodos de «Element» simplemente toman un ID o una referencia del objeto a Element que usted quiere manipular. Aquí tiene una mirada a algunos de los métodos más útiles:
// Esconder el elemento
Element.hide(elemento)
// Mostrar el elemento
Element.show(elemento)
// Añadir una clase CSS al elemento
Element.addClassName(elemento, "ClaseCSS")
// Quitar la clase CSS del elemento
Element.removeClassName(elemento, "ClaseCSS")
// Devuelve verdadero si el elemento tiene la clase CSS
Element.hasClassName(elemento, "ClaseCSS")
El objeto Insertion añade fragmentos de HTML en, y alrededor de, un Elemento. Hay cuatro tipos de Insertion: Before (antes), After (después), Top (cima) and Bottom (inferior). Esto le muestra como añadiría algún HTML antes de un elemento con el ID "myelement":
new Insertion.Before("myelement", "<p>I'm before!</p>");
El objeto Position puede indicar la posición en pantalla, y proporcionar información sobre la posición en relación con otros elementos de forma compatible con los navegadores. Esto debe ocupar la mayor parte del código complicado de animaciones, efectos y del código de arrastrar y soltar.
Los objetos Form y Field prevén un número de funciones simples pero convenientes para trabajar con formularios y campos «input», así como el código que soporta la puesta en práctica de AJAX con Prototype.
Generalmente, los métodos del objeto Form toman una ID o una referencia del objeto a un elemento:
// Deshabilita todos los campos de un formulario
Form.disable(formulario)
// Habilita todos los campos de un formulario
Form.enable(formulario)
// Limpia todos los campos de un formulario
Form.reset(formulario)
// Devuelve una lista con todos los valores del formulario
Form.getElements(formulario)
// Enfocar el primer campo
Form.focusFirstElement(formulario)
El objeto Field trata con elementos individuales del formulario y sus métodos típicamente toman un ID o una referencia del objeto a un elemento de un modo muy similar al objeto Form:
// Limpia el o los campos, acepta cualquier número de argumentos
Field.clear(campo1, campo2)
// Devuelve el foco a un campo
Field.focus(campo)
// Selecciona un campo
Field.select(campo)
La serialización del Formulario
En términos de Prototype, serializar un formulario significa leer todos los elementos del formulario y convertirlos en una cadena codificada en URL similar a la que sería enviado si usted aceptara el formulario. Por ejemplo:
<form id="busqueda" action="busqueda.php" method="post">
<input type="text" name="consultar" value="algo" />
<select name="campo">
<option value="nombre">Nombre del Artista</option>
<option value="titulo" selected="selected">Titulo de la canción</option>
</select>
<input type="submit" name="submit" value="Buscar" />
</form>
Form.serialize($("busqueda"))
Note que Form.serialize ingeniosamente deja de lado las diferentes maneras en que los elementos del formulario son accesados, de modo que inputs, selects, checkboxes y los radio buttons son manejados correctamente. Form.serialize es útil para varias tareas, pero es el mejor cuando trabajamos con AJAX.
Form. Observer y Form.Element. Observer permiten observar un formulario y enviar “callbacks” cuando los datos cambien. Estos son actualmente dos versiones de cada “observer” que verifican el valor actualizado. El primero es un observador periódico, que trabaja así:
new Form. Observer($("myform"), 1, myCallBackFunction);
new Form.Element. Observer($("myfield"), 1, myCallBackFunction);
Estos «observadores» comprueban cada segundo si los datos se han modificado y, si esto es así, llamará a myCallBackFunction.
El segundo tipo de «observador» está basado en los eventos y solamente realizará la comprobación cuando se produzca la modificación o un clic-evento para los elementos. Ejemplo:
new Form.EventObserver($("myform"), myCallBackFunction);
new Form.Element.EventObserver($("myfield", myCallbackFunction);
Si en todos los campos del formulario se colocan «observadores», tendremos una manera mucho más eficiente de observar el formulario. Pero, si se quiere “observar” los cambios de elementos que no soportan estos eventos, se debe usar los observadores periódicos.
Es totalmente posible realizar estas funciones sin emplear Prototype, pero demandaría un gran esfuerzo y muchas líneas de código, en una palabra se intentaría reinventar la rueda, «para que programar algo si ya existe», solamente hay que usarlo y aportar a la modificación de lo que ya está hecho. Por eso Prototype es un framework, una biblioteca lista para ser usada en un ambiente de producción.
La Web 2.0 ya es un hecho y Prototype está pensado para ello, para aprovechar al máximo la productividad y extender las fronteras de las web's ágiles, dinámicas y sencillas.
Al comparar Prototype con otro framework, hay que distinguir el propósito de cada uno. Supongamos que se desea implementar AJAX en un proyecto basado en PHP y se decide implementar PROTOTYPE como framework. En tal caso este no sería recomendable, dado que para PHP existe otro framework más apropiado llamado Xajax. En cambio si se desarrolla con Ruby la opción es Prototype, el cual ya viene integrado en Rails
Es difícil compararlos a todos. Sin embargo, todos proveen de un mejor servicio tanto para el cliente y una manera de producir más rápida para el desarrollador. Cuando FLASH parecía copar el mercado de las aplicaciones web, hoy AJAX se lleva el premio y todas apuntan a implementar esta Técnica.
Prototype es un framework más que implementa AJAX, si se lo compara con otro puede ganar o perder, pero esta un paso adelante del resto en lo que respecta al desarrollo de páginas ágiles e interactiva. El mundo cambió y hace uso de las bondades de la Web 2.0, Prototype brinda su aporte a este auge, para lograr mejores servicios a menor costo de desarrollo.
Con la introducción de AJAX en aplicaciones Web el manejo del objeto XMLHttpRequest se hace simple. En una secuencia en donde el usuario interactúa con la Web y provoca una petición, se crea un objeto XMLHttpRequest, luego este objeto realiza una llamada al servidor solicitando el evento. la petición se procesa en el servidor y devuelve un resultado en formato XML, o texto plano, o JavaScript, etc. que contienen el resultado de la petición. Luego el objeto XMLHttpRequest hace un llamado a la función callback() para procesar el resultado y por último se actualiza el DOM (Document Object Model) con el resultado devuelto.
De esta manera AJAX permite lograr páginas rápidas y ágiles brindado un servicio mejor al usuario.