La forma correcta de usar window.onload
En ocasiones, necesitamos ejecutar funciones javascript al cargarse una página (validaciones, autocompletados...).
Lo típico es hacerlo en el evento onload del body o poniendo las llamadas a nuestras funciones javascript dentro del código para que se vayan ejecutando mientras se carga la página, ésta sería la forma intrusiva de hacerlo, la forma no intrusiva sería utilizar window.onload.
window.onload = mifuncion();
Hay un problema que fácilmente nos puede surgir, cuando tenemos varias asignaciones a window.onload, ya que se ejecutará sólo la última.
En un principio se me ocurrió solucionarlo con una asignación común para toda la web, el problema es evidente, para una web más o menos grande llegaría a ser una macro-función, además de ser una solución nada elegante.
Al final a googleando un poco, acabé encontrando la solución en el blog de Robert Hahn, donde plantea tres formas de hacerlo para "que funcione", y una solución que al parecer es la ideal, simplemente es asignar a window.onload ésta función que nos devuelve una función anónima:
function makeDoubleDelegate(function1, function2) { return function() { if (function1) function1(); if (function2) function2(); } }
Para probarlo simplemente con éste código, podemos ver que funcina correctamente:
window.onload = makeDoubleDelegate(window.onload, alert('1')); window.onload = makeDoubleDelegate(window.onload, alert('2')); window.onload = makeDoubleDelegate(window.onload, alert('3'));