Javascript

JS Output

Manipulando el contenido de un elemento.

Codigo


    <p id="demo"></p>
    <script>
        document.getElementById("demo").innerHTML="Hola mundo";
    <script/>
                    

Resultado

Insertando texto nuevo sin un elemento.

Codigo


    <script>
        document.write("<h5>Hola Mundo</h5>";
    <script/>
                        

Resultado

Peligro, destruir documento.

Codigo


    <script>
    function confirmar()
        {
            if(confirm("Estas seguro?!"))
                document.write("<h5>Que pasara?</h5>");
        }
    <script/>
    <button onclick=confirmar()>NO PULSES ESTE BOTON</button>
                        

Resultado

JS Variables

Variables en javascript.

Codigo


    <script>
            var h = "Hola";
            var w = "Mundo";
            document.write("<p>" + h + w + "</p>");
            h = 1;
            w = 2;
            document.write("<p>" + h + w + "</p>");
    <script/>
                    

Resultado

JS Data Types

Tipos de datos dinamicos.

Codigo


    <script>
            var variable;
            document.write(variable + "<br />");
            variable = "Soy un string";
            document.write(variable + "<br />");
            variable = 1;
            document.write(variable + "<br />");
            variable = true;
            document.write(variable + "<br />");
    <script/>
                    

Resultado

Arrays

Codigo


    <script>
            var aray = new Array();
            aray[0] = "Hola";
            aray[1] = "Mundo";
            aray.push("El metodo push nos sirve para a��adir un elemento nuevo al array");
            document.write(aray + "<br />");
            aray.pop(3); // el metodo pop lo podemos usar para eliminar una posicion del array
            aray['A la una posion es un string'] = 5;
            aray.forEach(function(a){
                    document.write(a + "<br />");
            });
            document.write(aray['A la una posion es un string'] + "<br />");
    <script/>
                    

Resultado

Objetos(JSON)

Codigo


    <script>
        var jsn = {
            'persona': [{
                    'nombre': "Pepe",
                    'sexo': "hombre"
                },
                {
                    'nombre': "Pepa",
                    'sexo': "mujer"
                }
            ]};
        document.write(jsn  + "<br/>");
        document.write(jsn['persona'][0].nombre + " - ");
        document.write(jsn['persona'][0].sexo + "<br/>");
        document.write(jsn['persona'][1].nombre + " - ");
        document.write(jsn['persona'][1].sexo + "<br/>");
    </script>
                    

Resultado

JS Objects

Objetos en javascript.

Codigo


    <table>
        <tr>
            <td><canvas id="canvas" tabindex="0" width="200" height="100" style="border: solid black 1px;"></canvas></td>
            <td>
                w       Arriba<br/>
                s       Abajo<br/>
                a       Izquierda<br/>
                d       Derecha<br/>
            </td>
        </tr>
    </table>
    <script>
        var objeto = function(x, y)
        {
            this.x = x;
            this.y = y;
            this.l = function(){this.x-=5;};
            this.r = function(){this.x+=5;};
            this.u = function(){this.y-=5;};
            this.d = function(){this.y+=5;};
            this.getX = function(){return this.x;};
            this.getY = function(){return this.y;};
        };
        var instancia = new objeto(10, 10);
        var ctx = document.getElementById("canvas").getContext('2d');
        ctx.fillRect(instancia.getX(), instancia.getY(), 10 ,10);
        document.getElementById("canvas").addEventListener('keydown',function(e){
            ctx.clearRect(instancia.getX(), instancia.getY(), 10 ,10);
            if(e.keyCode==38) instancia.u();
            if(e.keyCode==40) instancia.d();
            if(e.keyCode==37) instancia.l();
            if(e.keyCode==39) instancia.r();
            ctx.fillRect(instancia.getX(), instancia.getY(), 10 ,10);
        });
    </script>
                    

Resultado

w Arriba
s Abajo
a Izquierda
d Derecha

JS Functions

Funciones.

Codigo


    Parametro: <input type="text" id="inText">
    <button onclick="funcion(inText.value);">Ejecutar funcion</button><br/>
    <button onclick="inText.value=retorna();">Establecer valor por retorno de variable</button>
    <script>
        function funcion(a)
        {
            if(a)
                alert("Parametro " + a);
            else
                alert("No se a pasado ningun parametro");
        }
        function retorna()
        {
            return 5;
        }
    </script>
                    

Resultado

Parametro:

JS Operators

Operadores aritmeticos.

Codigo


    <table>
        <tr>
            <td><span id="operActual">Suma</span></td>
        </tr>
        <tr>
            <td>
                <button onclick="aumenta('num1');">++</button>
            </td>
            <td></td>
            <td>
                <button onclick="aumenta('num2');">++</button>
            </td>
        </tr>
        <tr>
            <td>
                <input type="text" id="num1" onkeypress="compNum(event);" onchange="calcula();">
            </td>
            <td>
                <select onchange="cambiaOperacion(this)">
                    <option>+</option>
                    <option>-</option>
                    <option>*</option>
                    <option>/</option>
                    <option>%</option>
                </select>
            </td>
            <td>
                <input type="text" id="num2" onkeypress="compNum(event);" onchange="calcula();">
            </td>
            <td>= <input type="text" id="res"/></td>
        </tr>
        <tr>
            <td>
                <button onclick="disminuye('num1');">--</button>
            </td>
            <td></td>
            <td>
                <button onclick="disminuye('num2');">--</button>
            </td>
        </tr>
    </table>

    <script>
        var selectVal = '+';
        function compNum(e)
        {
            if((e.keyCode-48 < 0 || e.keyCode-48 > 9) && e.keyCode != 46  && e.keyCode != 45) e.preventDefault();
        }
        function cambiaOperacion(e)
        {
            selectVal = e.options[e.selectedIndex].value;
            if(selectVal == '+')
                document.getElementById("operActual").innerHTML="Suma";
            else if(selectVal == '-')
                document.getElementById("operActual").innerHTML="Resta";
            else if(selectVal == '*')
                document.getElementById("operActual").innerHTML="Multiplicacion";
            else if(selectVal == '/')
                document.getElementById("operActual").innerHTML="Division";
            else if(selectVal == '%')
                document.getElementById("operActual").innerHTML="Modulo";
            calcula();
        }
        function aumenta(num)
        {
            document.getElementById(num).value++;
            calcula();
        }
        function disminuye(num)
        {
            document.getElementById(num).value--;
            calcula();
        }
        function calcula()
        {
            var num1 = parseFloat(document.getElementById('num1').value);
            var num2 = parseFloat(document.getElementById('num2').value);
            var res = document.getElementById('res');
            if(selectVal == '+') res.value = num1 + num2;
            else if(selectVal == '-') res.value = num1 - num2;
            else if(selectVal == '*') res.value = num1 * num2;
            else if(selectVal == '/') res.value = num1 / num2;
            else if(selectVal == '%') res.value = num1 % num2;

        }
    </script>

                    

Resultado

Suma
=

Operadores de assignacion.

Codigo


    x: <input type="text" id="numX" onchange="cal2()" onkeypress="compNum(event);">
    y: <input type="text" id='numY' onchange="cal2()" onkeypress="compNum(event);"><br/>
    <table>
        <tr>
            <td>x=y</td>
            <td>x = <span id='eql'></span><br/></td>
        </tr>
        <tr>
            <td>x+=y</td>
            <td>x = <span id='plus'></span><br/></td>
        </tr>
        <tr>
            <td>x-=y</td>
            <td>x = <span id='min'></span><br/></td>
        </tr>
        <tr>
            <td>x*=y</td>
            <td>x = <span id='mult'></span><br/></td>
        </tr>
        <tr>
            <td>x/=y</td>
            <td>x = <span id='div'></span><br/></td>
        </tr>
        <tr>
            <td>x%=y</td>
            <td>x = <span id='mod'></span><br/></td>
        </tr>
    </table>

    <script>
        function eql(){
            var x = parseFloat(document.getElementById('numX').value);
            var y = parseFloat(document.getElementById('numY').value);
            x=y;
            return x;
        }
        function plus(){
            var x = parseFloat(document.getElementById('numX').value);
            var y = parseFloat(document.getElementById('numY').value);
            x+=y;
            return x;
        }
        function min(){
            var x = parseFloat(document.getElementById('numX').value);
            var y = parseFloat(document.getElementById('numY').value);
            x-=y;
            return x;
        }
        function mult(){
            var x = parseFloat(document.getElementById('numX').value);
            var y = parseFloat(document.getElementById('numY').value);
            x*=y;
            return x;
        }
        function div(){
            var x = parseFloat(document.getElementById('numX').value);
            var y = parseFloat(document.getElementById('numY').value);
            x/=y;
            return x;
        }
        function mod(){
            var x = parseFloat(document.getElementById('numX').value);
            var y = parseFloat(document.getElementById('numY').value);
            x%=y;
            return x;
        }
        function compNum(e)
        {
            if((e.keyCode-48 < 0 || e.keyCode-48 > 9) && e.keyCode != 46  && e.keyCode != 45) e.preventDefault();
        }
        cal2()
        function cal2(){
            document.getElementById("eql").innerHTML= eql();
            document.getElementById("plus").innerHTML= plus();
            document.getElementById("min").innerHTML= min();
            document.getElementById("mult").innerHTML= mult();
            document.getElementById("div").innerHTML= div();
            document.getElementById("mod").innerHTML= mod();
        }
    </script>
                    

Resultado

x: y:
x=y x =
x+=y x =
x-=y x =
x*=y x =
x/=y x =
x%=y x =

Operador + con Strings

Codigo


    <input type="text" id="str1" onchange="strcmp();"> + <input type="text" id="str2" onchange="strcmp();"> = <span id='resStr'/>
    <script>
        function strcmp(){
            var str1 = document.getElementById('str1').value;
            var str2 = document.getElementById('str2').value;
            document.getElementById('resStr').innerHTML = str1 + str2;
        }
    </script>
                    

Resultado

+ =

JS Comparisons

Operadores de comparacion.

Codigo


    Introduzaca el valor entre comillas dobles o simples para strings<br/>
    x = <input type='text' id='valIfX' onchange="funcionIf();"><br/>
    y = <input type='text' id='valIfY' onchange="funcionIf();"><br/>
    <br/>
    <table>
        <tr>
            <td>if(x == y)</td>
            <td id='ifIgual'></td>
        </tr>
        <tr>
            <td>if(x === y)</td>
            <td id='ifIgual2'></td>
        </tr>
        <tr>
            <td>if(x != y)</td>
            <td id='ifNoIgual'></td>
        </tr>
        <tr>
            <td>if(x !== y)</td>
            <td id='ifNoIgual2'></td>
        </tr>
        <tr>
            <td>if(x > y)</td>
            <td id='ifMayor'></td>
        </tr>
        <tr>
            <td>if(x < y)</td>
            <td id='ifMenor'></td>
        </tr>
        <tr>
            <td>if(x >= y)</td>
            <td id='ifMayorIgual'></td>
        </tr>
        <tr>
            <td>if(x <= y)</td>
            <td id='ifMenorIgual'></td>
        </tr>
    </table>
    <script>
        function funcionIf(){
            try{
            var x = eval(document.getElementById('valIfX').value);
            var y = eval(document.getElementById('valIfY').value);

            document.getElementById("ifIgual").innerHTML = (x == y);
            document.getElementById("ifIgual2").innerHTML = (x === y);
            document.getElementById("ifNoIgual").innerHTML = (x != y);
            document.getElementById("ifNoIgual2").innerHTML = (x !== y);
            document.getElementById("ifMayor").innerHTML = (x > y);
            document.getElementById("ifMenor").innerHTML = (x < y);
            document.getElementById("ifMayorIgual").innerHTML = (x >= y);
            document.getElementById("ifMenorIgual").innerHTML = (x <= y)
            }
            catch(err){
            document.getElementById("ifIgual").innerHTML = "";
            document.getElementById("ifIgual2").innerHTML = "";
            document.getElementById("ifNoIgual").innerHTML = "";
            document.getElementById("ifNoIgual2").innerHTML = "";
            document.getElementById("ifMayor").innerHTML = "";
            document.getElementById("ifMenor").innerHTML = "";
            document.getElementById("ifMayorIgual").innerHTML = "";
            document.getElementById("ifMenorIgual").innerHTML = "";
            }
        }
    </script>
                    

Resultado

Introduzaca el valor entre comillas dobles o simples para strings
x =
y =

if(x == y)
if(x === y)
if(x != y)
if(x !== y)
if(x > y)
if(x < y)
if(x >= y)
if(x <= y)

Operadores logicos.

Codigo


    <code>
        <table>
            <tr>
                <td>
                    if(
                    <select id='if11' onchange="logicalIf('resIf1');">
                        <option>true</option>
                        <option>false</option>
                    </select>
                    &&
                    <select id='if12' onchange="logicalIf('resIf1');">
                        <option>true</option>
                        <option>false</option>
                    </select>
                    )
                </td>
                <td id='resIf1'>true</td>
            </tr>
            <tr>
                <td>
                    if(
                    <select id='if21' onchange="logicalIf('resIf2');">
                        <option>true</option>
                        <option>false</option>
                    </select>
                    ||
                    <select id='if22' onchange="logicalIf('resIf2');">
                        <option>true</option>
                        <option>false</option>
                    </select>
                    )
                </td>
                <td id='resIf2'>true</td>
            </tr>
            <tr>
                <td>
                    if(
                    !<select id='if3' onchange="logicalIf('resIf3');">
                        <option>true</option>
                        <option>false</option>
                    </select>
                    )
                </td>
                <td id='resIf3'>false</td>
            </tr>
        </table>
    </code>
    <script>
        function logicalIf(res)
        {
            if(res == 'resIf1')
                {
                    var var1 = eval(document.getElementById('if11').options[document.getElementById('if11').selectedIndex].value);
                    var var2 = eval(document.getElementById('if12').options[document.getElementById('if12').selectedIndex].value);
                    document.getElementById(res).innerHTML = (var1 && var2);
                }
            if(res == 'resIf2')
                {
                    var var1 = eval(document.getElementById('if21').options[document.getElementById('if21').selectedIndex].value);
                    var var2 = eval(document.getElementById('if22').options[document.getElementById('if22').selectedIndex].value);
                    document.getElementById(res).innerHTML = (var1 || var2);
                }
            if(res == 'resIf3')
                {
                    var var1 = eval(document.getElementById('if3').options[document.getElementById('if3').selectedIndex].value);
                    document.getElementById(res).innerHTML = (!var1);
                }
        }
    </script>
                    

Resultado

if( && ) true
if( || ) true
if( ! ) false

Operador condicional (condicion ternaria).

Codigo


    var resultado=(
    <select id='condTernario' onchange="ternaryIf(this);">
        <option>true</option>
        <option>false</option>
    </select>
    )?"valor 1":"valor 2";<br/>
    resultado = <span id="resTernario">valor 1</span>
    <script>
        function ternaryIf(sel)
        {
            var condition = eval(sel.options[sel.selectedIndex].value);
            document.getElementById('resTernario').innerHTML = (condition)?"valor 1":"valor 2";
        }
    </script>
                    

Resultado

var resultado=( )?"valor 1":"valor 2";
resultado = valor 1

JS Conditions

Bloques:
-> if
-> if ... else
-> if ... else if ... else

Codigo


    if(
    <select id='ifelse1' onchange="ifelse();">
        <option>true</option>
        <option>false</option>
    </select>
    )<br/>
    {<br/>
    <div id="ifelseres1"></div>
    }<br/><br/>

    if(
    <select id='ifelse2' onchange="ifelse();">
        <option>true</option>
        <option>false</option>
    </select>
    )<br/>
    {<br/>
    <div id="ifelseres21"></div>
    }<br/>
    else<br/>
    {
    <div id="ifelseres22"></div>
    }<br/><br/>

    if(
    <select id='ifelse31' onchange="ifelse();">
        <option>true</option>
        <option>false</option>
    </select>
    )<br/>
    {<br/>
    <div id="ifelseres31"></div>
    }<br/>
    else if(
    <select id='ifelse32' onchange="ifelse();">
        <option>true</option>
        <option>false</option>
    </select>
    )<br/>
    {<br/>
    <div id="ifelseres32"></div>
    }<br/>
    else <br/>
    {<br/>
    <div id="ifelseres33"></div>
    }
    <script>
        function ifelse(){
            //esta variable contiene una imagen comprimida en una string base64
            var img = "";

            var ifelse1 = eval(document.getElementById('ifelse1').options[document.getElementById('ifelse1').selectedIndex].value);
            var ifelse2 = eval(document.getElementById('ifelse2').options[document.getElementById('ifelse2').selectedIndex].value);
            var ifelse31 = eval(document.getElementById('ifelse31').options[document.getElementById('ifelse31').selectedIndex].value);
            var ifelse32 = eval(document.getElementById('ifelse32').options[document.getElementById('ifelse32').selectedIndex].value);                            

            var ifelseres1 = document.getElementById("ifelseres1");
            var ifelseres21 = document.getElementById("ifelseres21");
            var ifelseres22 = document.getElementById("ifelseres22");
            var ifelseres31 = document.getElementById("ifelseres31");
            var ifelseres32 = document.getElementById("ifelseres32");
            var ifelseres33 = document.getElementById("ifelseres33");

            ifelseres1.innerHTML = "";
            ifelseres21.innerHTML = "";
            ifelseres22.innerHTML = "";
            ifelseres31.innerHTML = "";
            ifelseres32.innerHTML = "";
            ifelseres33.innerHTML = "";

            if(ifelse1)
                ifelseres1.innerHTML = '<img src="' + img +'" style="width: 30px; height: 30px; margin-left: 30px;"/>';

            if(ifelse2)
                ifelseres21.innerHTML = '<img src="' + img +'" style="width: 30px; height: 30px; margin-left: 30px;"/>';
            else
                ifelseres22.innerHTML = '<img src="' + img +'" style="width: 30px; height: 30px; margin-left: 30px;"/>';

            if(ifelse31)
                ifelseres31.innerHTML = '<img src="' + img +'" style="width: 30px; height: 30px; margin-left: 30px;"/>';
            else if(ifelse32)
                ifelseres32.innerHTML = '<img src="' + img +'" style="width: 30px; height: 30px; margin-left: 30px;"/>';
            else
                ifelseres33.innerHTML = '<img src="' + img +'" style="width: 30px; height: 30px; margin-left: 30px;"/>';
        }
    </script>
                    

Resultado

if( )
{
}

if( )
{
}
else
{
}

if( )
{
}
else if( )
{
}
else
{
}

JS Switch

Bloque switch case.

Codigo


    <button onclick="dice();">Tirar dado</button>
    <span id="dado"></span>
    <script>
        function dice()
        {
            var dado = document.getElementById('dado');
            var rand =  parseInt(Math.random()*6+1);
            var img;
            switch(rand)
            {
                case 1:
                    img = "";
                    break;
                case 2:
                    img = "";
                    break;
                case 3:
                    img = "";
                    break;
                case 4:
                    img = "";
                    break;
                case 5:
                    img = "";
                    break;
                case 6:
                    img = "";
                    break;
            }
            dado.innerHTML = '<img src="' + img +'" style="border: 3px black solid; border-radius: 10px 10px 10px 10px;"/>';
        }
    </script>
                    

Resultado

JS Loop For

Bucle for.

Codigo


    Fibonacci = 
    <span id="fibo"></span>
    <script>
        var n = 1, m = 1;
        var str = n + ", " + m;
        for(i=0; i < 50; i++)
            {
                var temp = n+m;
                str += ", " + temp;
                n = m;
                m = temp;
            }
        document.getElementById('fibo').innerHTML = str;
    </script>
                    

Resultado

Fibonacci =

Bucle for in.

Codigo


    <span id="forin"></span>
    <script>
        var player = {Nombre:"Pepito", Nivel:"80", Raza:"Orco"}
        for(i in player)
            document.getElementById('forin').innerHTML += i + ": " + player[i] + "<br/>";
    </script>
                    

Resultado

JS Loop While

Bucle while.

Codigo


    Fibonacci = 
    <span id="fibowhile"></span>
    <script>
        var n = 1, m = 1;
        var str = n + ", " + m;
        var i = 0;
        while(i < 50)
            {
                var temp = n+m;
                str += ", " + temp;
                n = m;
                m = temp;
                i++;
            }
        document.getElementById('fibowhile').innerHTML = str;
    </script>
                    

Resultado

Fibonacci =

Bucle do ... while.

Codigo


    Fibonacci = 
    <span id="fibodowhile"></span>
    <script>
        var n = 1, m = 1;
        var str = n + ", " + m;
        var i = 0;
        do
        {
            var temp = n+m;
            str += ", " + temp;
            n = m;
            m = temp;
            i++;
        }while(i != 0 && i < 50);
        //Per veure la diferencia entre while y do while posem que no entri mentre i sigui igual a 0
        //com la primera vegada no mira la condicio entrara al while y dins augmentara la i per tant seguira
        document.getElementById('fibodowhile').innerHTML = str;
    </script>
                    

Resultado

Fibonacci =