|
Ejemplos sencillos
var x; // define la variable x, aunque no tiene ningún valor asignado por defecto
var y = 2; // define la variable y y le asigna el valor 2 a ella Sin embargo, la mayoria de los entornos de ejeciocion tiene un objeto llamado console que puede ser usado para imprimir por el flujo de salida de la consola de depuración. He aquí un simple programa que imprime "Hello world!":
console.log("Hello world!");
Una funcion recursiva:
function factorial(n) {
if (n == 0) { return 1; } return n * factorial(n - 1); } Ejemplos de funcion anonima (o funcion lambda) y una clausura:
var displayClosure = function() {
var count = 0; return function () { return ++count; }; } var inc = displayClosure(); inc(); // devuelve 1 inc(); // devuelve 2 inc(); // devuelve 3 Las expresiones con invocación automática permiten a las funciones pasarle variables por parámetro dentro de sus propias clausuras.
var v;
v = 1; var getValue = (function(v) { return function() {return v;}; }(v)); v = 2; getValue(); // 1 Ejemplos mas avanzados
/* Busca el mínimo común múltiplo (MCM) de dos números */
function LCMCalculator(x, y) { // función constructora var checkInt = function (x) { // función interior if (x % 1 !== 0) { throw new TypeError(x + " no es un entero"); // lanza una excepción } return x; }; this.a = checkInt(x) // puntos y coma son opcionales this.b = checkInt(y); } // El prototipo de las instancias de objeto creados por el constructor es el de la propiedad “prototype” del constructor. LCMCalculator.prototype = { // objeto definido como literal constructor: LCMCalculator, // cuando reasignamos un prototipo, establecemos correctamente su propiedad constructor gcd: function () { // método que calcula el máximo común divisor // Algoritmo de Euclides: var a = Math.abs(this.a), b = Math.abs(this.b), t; if (a < b) { // intercambiamos variables t = b; b = a; a = t; } while (b !== 0) { t = b; b = a % b; a = t; } // Solo necesitamos calcular el MCD una vez, por lo tanto 'redefinimos' este método. // (Realmente no es una redefinición—está definida en la propia instancia, por lo tanto // this.gcd se refiere a esta 'redefinición' en vez de a LCMCalculator.prototype.gcd). // Además, 'gcd' === "gcd", this['gcd'] === this.gcd this['gcd'] = function () { return a; }; return a; }, // Los nombres de las propiedades del objeto pueden ser especificados con cadenas delimitadas con comillas simples (') o dobles (“). "lcm" : function () { // Los nombres de las variables no colisionan con las propiedades del objeto. Por ejemplo: |lcm| no es |this.lcm|. // No usar |this.a * this.b| para evitar problemas con cálculos en coma flotante. var lcm = this.a / this.gcd() * this.b; // Sólo necesitamos calcular MCM una vez, por lo tanto "redefinimos" este método. this.lcm = function () { return lcm; }; return lcm; }, toString: function () { return "LCMCalculator: a = " + this.a + ", b = " + this.b; } }; // Definimos una función genérica para imprimir un resultado; esta implementación solo funciona en los navegadores web function output(x) { document.body.appendChild(document.createTextNode(x)); document.body.appendChild(document.createElement('br')); } // Nota: Los métodos.map() y.forEach() del prototipo Array están definidos en JavaScript 1.6. // Estos métodos son usados aquí para demostrar la naturaleza funcional inherente del lenguaje. [[25, 55], [21, 56], [22, 58], [28, 56]].map(function (pair) { // construcción literal de un Array + función de mapeo. return new LCMCalculator(pair[0], pair[1]); }).sort(function (a, b) { // ordenamos la colección por medio de esta función return a.lcm() - b.lcm(); }).forEach(function (obj) { output(obj + ", gcd = " + obj.gcd() + ", lcm = " + obj.lcm()); }); El siguiente ejemplo muestra la salida que deberia ser mostrada en la ventana de un navegador.
LCMCalculator: a = 28, b = 56, gcd = 28, lcm = 56
LCMCalculator: a = 21, b = 56, gcd = 7, lcm = 168 LCMCalculator: a = 25, b = 55, gcd = 5, lcm = 275 LCMCalculator: a = 22, b = 58, gcd = 2, lcm = 638 |