Standaard is het bovenstaande niet mogelijk omdat er geen event afgaat op het DOM object op het moment dat de content wijzigt.
Voor dit doel heb ik een ChangeListener geschreven die van alle geregistreerde DOM objecten monitored of de content gewijzigd is. Als dit zo is dan word een callBack functie aangeroepen die het event kan afhandelen:
/**************************************************************************************************
Implemented a custom change event listener.
Reason for this is that on change of the content of the HTMLResults we have to act.
Action is doing an investigation of the html and if there is a script tag, evaluate the inside of the script.
This enables us to mimic a dbLookup in a view.
ChangeListener is generic, and just needs registering DOM objects with a callback function
***************************************************************************************************/
var ChangeListener =
{
registered: [],
register: function(objDom,callback)
{
objDom.contentlength = objDom.innerHTML.length;
objDom.checkchange = function()
{
if(this.contentlength!=this.innerHTML.length){
this.contentlength=this.innerHTML.length;
ChangeListener.notify(this);
}
};
var element ={
obj: objDom,
callback: callback
};
this.registered.push( element);
},
monitor: function()
{
var loop = setInterval( function()
{
for(var i=0;i
}
},10);
},
notify: function(obj)
{
for(var i=0;i
}
}
}
};
//start monitoring changes
ChangeListener.monitor();
Geen opmerkingen:
Een reactie posten