Ho il seguente codice JavascriptCome chiamo le funzioni di un oggetto all'interno dello stesso oggetto?
add_num = {
f: function(html, num) {
alert(this.page);
},
page : function() {
return parseInt(this.gup('page'));
},
gup : function(name) {
name = name.replace(/[\[]/,'\\\[').replace(/[\]]/,'\\\]');
var regex = new RegExp('[\\?&]'+name+'=([^&#]*)');
var results = regex.exec(window.location.href);
if(results == null)
return '';
else
return results[1];
}
}
Ma quando chiamo add_num.f() quello che ottengo da alert() è il codice effettivo della pagina. Cioè, restituisce
function() {
return parseInt(this.gup('page'));
}
Mi aspettavo un valore numerico e non alcun codice.
In realtà non si sta * chiamando * la funzione, ma è sufficiente passarla come oggetto a 'alert()'. Prova 'alert (this.page());'. –