viernes, 28 de junio de 2013

Inclusiones dinámicas de scripts en JavaScript

Verifica si ya se incluyó un script (en la sección de cabecera por defecto):

//------------------------------------------------------------------------------------------------
// Engines      JavaScript 1.2+
//              JScript    3+
// Environments NN6+ IE5+ MOZILLA1+ SAFARI1+
// DOM Level    1 Core
//------------------------------------------------------------------------------------------------
function included (s /* scr */, t /* tag-name (head by default) */)
{
    var d;
    if (!t) t = 'head';

    if (typeof s == 'string' && (d = s.indexOf('../')) != -1)
        s = s.substr(d + 3);

    d = document;
    t = d.getElementsByTagName(t);

    for (var i = 0, l = t.length, e; i < l; ++i)
    {
        e = t[i].getElementsByTagName('script');

        for (var j = 0, n = e.length; j < n; ++j)
            if (e[j].src && (s.test ? s.test(e[j].src) : e[j].src.lastIndexOf(s) != -1))
                return true;
    }

    return false;
}

Uso:

if (!included('my-file.js'))
{
    // TODO...
}

Incluye uno o varios scripts (en la sección de cabecera por defecto):

//------------------------------------------------------------------------------------------------
// Engines      JavaScript 1.2+
//              JScript    3+
// Environments NN6+ IE5+ MOZILLA1+ SAFARI1+
// DOM Level    1 Core
//------------------------------------------------------------------------------------------------
function include (/* arg1 [, ... [, argN]] */)
{
    var r = '', x = r;
    for (var d = document, i = 0, a = arguments, l = a.length, e, s; i < l; ++i)
    {
        if ((s = a[i]).root && (r = s.root + '').length > 0 && r.lastIndexOf('/') != r.length - 1)
            r += '/';
   
        if (s.extension && (x = s.extension + '').length > 0 && x.indexOf('.') != 0)
            x = '.' + x;

        if (s.src || typeof s == 'string')
        {
            e = d.createElement('script');
            e.setAttribute('src',  r + (s.src ? s.src : s) + x);
            e.setAttribute('type', s.type ? s.type : 'text/javascript');

            if (typeof s.onload == 'function')
            {
                if (e.readyState) 
                {
                    e.onreadystatechange = function ()
                    {
                        if (this.readyState == 'loaded' || this.readyState == 'complete')
                        {
                            delete this.onreadystatechange;
                            this.loaded();
                        }
                    }

                    e.loaded = s.onload;
                }
    
                else e.onload = s.onload;
            }

            d.getElementsByTagName(s.tag ? s.tag : 'head')[0].appendChild(e);
        }
    }
}

Uso:

if (!included('my-file1.js') && !included('my-file2.js')) include
(
      {root: 'my-path', extension: 'js'}
    , {src: 'my-file1', onload: function () { /* TODO... */ }}
    , {src: 'my-file2', onload: function () { /* TODO... */ }}
);

if (!included('my-file4.js'))
    include({src: 'my-file4.js', onload: function () { /* TODO... */ }});

Existe otro modo de hacerlo, usando ajax:

//------------------------------------------------------------------------------------------------
// Engines      JavaScript 1.2+
//              JScript    3+
// Environments NN7.1+ IE5+ MOZILLA1+ SAFARI1.2+
//------------------------------------------------------------------------------------------------
function loadscript (s /* url */, b /* eval? (Boolean) */)
{
    var r, x, w = window;
 
    if (w && w.XMLHttpRequest)
        r = new w.XMLHttpRequest();
 
    else if (typeof Components != 'undefined' && Components.classes)                               // XPCOM!
    {
        try
        {
            r = Components.classes['@mozilla.org/xmlextras/xmlhttprequest;1'].createInstance
            (
                Components.interfaces.nsIXMLHttpRequest
            );
        }
   
        catch (e)
        {
            r = null;
        }
    }
 
    else if ((x = w.ActiveXObject) || (x = w.GeckoActiveXObject)) 
    {
        try
        {
            r = new x('Msxml2.XMLHTTP');
        }
  
        catch (e)
        {
            try
            {
                r = new x('Microsoft.XMLHTTP'); 
            }

            catch(e)
            {
                r = null;
            }
        }
    }
 
    if (r)
    {
        r.open('GET', s, false);
        r.send(null);
  
        if (r.readyState == 4 && r.status == 200)
        {
            if (b) eval(r.responseText);
            else
            {
                (w = (x = document).createElement('script')).setAttribute('type', 'text/javascript');
                w.text = r.responseText;
                x.getElementsByTagName('head')[0].appendChild(w);
            }

            return true;
        }
    }
    
    return false;
}

Uso:

if (loadscript('my-file1.js'))
{
    //TODO...
}

loadscript('my-file2.js', true);

Macros de C en JavaScript

//-----------------------------------------------------------------------------------------------
// Engines       JavaScript 1+
//               JScript    1+
// Environments  NN2+ IE3+ WSH1+ MOZILLA1+ SAFARI1+
//-----------------------------------------------------------------------------------------------

function makeWORD (l, h) { return  l & 0xFF | (h & 0xFF) << 8;                                  } // 0-255 * 2
function loBYTE   (n)    { return  n & 0xFF;                                                    }
function hiBYTE   (n)    { return (n >> 8) & 0xFF;                                              }

//-----------------------------------------------------------------------------------------------

function make3BYTE (a, b, c)    { return makeWORD(a, b) | (c & 0xFF) << 16;                     } // 0-255 * 3
function RGB       (r, g, b)    { return make3BYTE(r, g, b);                                    }
function makeQBYTE (a, b, c, d) { return make3BYTE(a, b, c) | (d & 0xFF) << 24;                 } // 0-255 * 4
function RGBA      (r, g, b, a) { return makeQBYTE(r, g, b, a);                                 }
function h3BYTE    (n)          { return (n >> 16) & 0xFF;                                      }
function h4BYTE    (n)          { return (n >> 24) & 0xFF;                                      }
function getRValue (n)          { return loBYTE(n);                                             }
function getGValue (n)          { return hiBYTE(n);                                             }
function getBValue (n)          { return h3BYTE(n);                                             }
function getAValue (n)          { return h4BYTE(n);                                             }

//-----------------------------------------------------------------------------------------------

function makeLONG (l, h)   { return l & 0xFFFF | (h & 0xFFFF) << 16;                            } // 0-65535 * 2
function loWORD   (n)      { return  n & 0xFFFF;                                                }
function hiWORD   (n)      { return (n >> 16) & 0xFFFF;                                         }

jueves, 27 de junio de 2013

Cómo obtener la versión de JavaScript y JScript

//--------------------------------------------------------------------------------------------------
// Engines      JavaScript   1+
//              JScript      1+
// Environments NN2+ IE3+ WSH1+ MOZILLA1+ SAFARI1+
//--------------------------------------------------------------------------------------------------

// Global
//--------------------------------------------------------------------------------------------------

function  __this() { return this; }
var __g = __this();

//--------------------------------------------------------------------------------------------------

var __err_t = __g.Error;
var __num_t = __g.Number;
var __rex_t = __g.RegExp;

// JScript
//--------------------------------------------------------------------------------------------------

var  __jsm_; /*@cc_on __jsm_ = @_jscript_version; @cc_off @*/       
if (!__jsm_)
     __jsm_ = __err_t ? 5 : (__rex_t ? 3 : (__num_t.MAX_VALUE ? 2 : 1));

// JavaScript
//--------------------------------------------------------------------------------------------------

var __jsn_ = __err_t ? 1.5 : (__g.Infinity ? 1.3 : (__rex_t ? 1.2 : (__num_t.MAX_VALUE ? 1.1 : 1))); 

if (__jsn_ == 1.5)
    __jsn_ = eval('[]').reduce ? 1.8 : (__g.Iterator ? 1.7 : (eval('[]').map ? 1.6 : 1.5));