Skip to content

Enmascarar numero como dinero usando jQuery

by en 11 agosto, 2011

Es muy común que necesitemos mostrar formularios en los cuales debamos mostrar números como si fueran una determinada moneda. Usando C# en el code-behind es bastante fácil decirle a un double .ToString(“C0”);, lo que automáticamente pondrá el número en formato moneda según la configuración del Globalization de nuestro entorno.

Cuando se trata de HTML y si queremos evitar post-backs, esto se puede lograr con jQuery y un plugin que encontré llamado formatCurrency.

Primero debemos importar los scripts necesarios en nuestra solución

    <script src="Scripts/jquery-1.4.1.js" type="text/javascript"></script>
    <script src="Scripts/jquery.formatCurrency/jquery.formatCurrency-1.4.0.js" type="text/javascript"></script>
    <script src="Scripts/jquery.formatCurrency/i18n/jquery.formatCurrency.es-CL.js" type="text/javascript"></script>

Luego hay que llamar el procedimiento para que aplique el formato.

        function applyFormatCurrency(sender) {
            $(sender).formatCurrency({
                region: 'es-CL'
                , roundToDecimalPlace: -1
            });
        }

Luego donde quiero aplicar el formato. En este caso, en unos textboxes.

<label for="txt_onChange">En el evento onchange</label><input type="text" id="txt_onChange" onchange="applyFormatCurrency(this);" />
    <br /><label for="txt_onDemand">On demand</label><input type="text" id="txt_onDemand" /><input type="button" value="Aplciar formato" onclick="applyFormatCurrency(document.getElementById('txt_onDemand'));" />
    <br /><label for="txt_onKeyPressed">On KeyPressed</label><input type="text" id="txt_onKeyPressed" onkeypress="applyFormatCurrency(this);" />

Note que cada textbox tiene su propio evento en el que llamará a la función applyFormatCurrency.

A continuación el codigo del HTML completo copiar/pegar, renombrar las referencias a los scripts y empezar a jugar😉

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www.w3.org/1999/xhtml">
<head>
    <title>DEMO de Format Currency</title>
    <script src="Scripts/jquery-1.4.1.js" type="text/javascript"></script>
    <script src="Scripts/jquery.formatCurrency/jquery.formatCurrency-1.4.0.js" type="text/javascript"></script>
    <script src="Scripts/jquery.formatCurrency/i18n/jquery.formatCurrency.es-CL.js" type="text/javascript"></script>
    <script type="text/javascript">
        function applyFormatCurrency(sender) {
            $(sender).formatCurrency({
                region: 'es-CL'
                , roundToDecimalPlace: -1
            });
        }
    </script>
</head>
<body>
    <label for="txt_onChange">En el evento onchange</label><input type="text" id="txt_onChange" onchange="applyFormatCurrency(this);" />
    <br /><label for="txt_onDemand">On demand</label><input type="text" id="txt_onDemand" /><input type="button" value="Aplciar formato" onclick="applyFormatCurrency(document.getElementById('txt_onDemand'));" />
    <br /><label for="txt_onKeyPressed">On KeyPressed</label><input type="text" id="txt_onKeyPressed" onkeypress="applyFormatCurrency(this);" />
</body>
</html>

Links:

Enjoy😉

From → JavaScript, jQuery

2 comentarios
  1. Fabian Ruedas permalink

    Excelente amigo me ayudo mucho, tengo una duda como lo puedo aplicar a un campo que solo me muestra un resultado de una funcion javascript?, quiero decir que en ningun momento sera manipulado por el cliente solo muestra el valor y ya…

Responder

Introduce tus datos o haz clic en un icono para iniciar sesión:

Logo de WordPress.com

Estás comentando usando tu cuenta de WordPress.com. Cerrar sesión / Cambiar )

Imagen de Twitter

Estás comentando usando tu cuenta de Twitter. Cerrar sesión / Cambiar )

Foto de Facebook

Estás comentando usando tu cuenta de Facebook. Cerrar sesión / Cambiar )

Google+ photo

Estás comentando usando tu cuenta de Google+. Cerrar sesión / Cambiar )

Conectando a %s

A %d blogueros les gusta esto: