Comment j'ai résolu cette étape?
juste comme ça :
setTimeout((function(_deepFunction ,_deepData){
var _deepResultFunction = function _deepResultFunction(){
_deepFunction(_deepData);
};
return _deepResultFunction;
})(fromOuterFunction, fromOuterData ) , 1000 );
setTimeout attend une référence à une fonction, donc je l'ai créée dans une fermeture, qui interprète mes données et retourne une fonction avec une bonne instance de mes données!
Vous pouvez peut-être améliorer cette partie:
_deepFunction(_deepData);
// change to something like :
_deepFunction.apply(contextFromParams , args);
Je l'ai testé sur Chrome, Firefox et IE et il s'exécute bien, je ne connais pas les performances mais j'en avais besoin pour fonctionner.
un exemple de test:
myDelay_function = function(fn , params , ctxt , _time){
setTimeout((function(_deepFunction ,_deepData, _deepCtxt){
var _deepResultFunction = function _deepResultFunction(){
//_deepFunction(_deepData);
_deepFunction.call( _deepCtxt , _deepData);
};
return _deepResultFunction;
})(fn , params , ctxt)
, _time)
};
// the function to be used :
myFunc = function(param){ console.log(param + this.name) }
// note that we call this.name
// a context object :
myObjet = {
id : "myId" ,
name : "myName"
}
// setting a parmeter
myParamter = "I am the outer parameter : ";
//and now let's make the call :
myDelay_function(myFunc , myParamter , myObjet , 1000)
// this will produce this result on the console line :
// I am the outer parameter : myName
Vous pouvez peut-être modifier la signature pour la rendre plus conforme:
myNass_setTimeOut = function (fn , _time , params , ctxt ){
return setTimeout((function(_deepFunction ,_deepData, _deepCtxt){
var _deepResultFunction = function _deepResultFunction(){
//_deepFunction(_deepData);
_deepFunction.apply( _deepCtxt , _deepData);
};
return _deepResultFunction;
})(fn , params , ctxt)
, _time)
};
// and try again :
for(var i=0; i<10; i++){
myNass_setTimeOut(console.log ,1000 , [i] , console)
}
Et enfin pour répondre à la question d'origine:
myNass_setTimeOut( postinsql, 4000, topicId );
J'espère que cela peut aider!
ps: désolé mais l'anglais ce n'est pas ma langue maternelle!