Il metodo handler.apply()
costituisce una trap per una chiamata a funzione.
Il sorgente di questo esempio interattivo è memorizzato in una repository GitHub. Qualora volessi contribuire al progetto degli esempi interattivi, puoi farlo clonando https://github.com/mdn/interactive-examples e inviandoci una pull request.
Sintassi
var p = new Proxy(target, {
apply: function(target, thisArg, argumentsList) {
}
});
Parametri
I seguenti parametri vengono passati al metodo apply
. this
è legato all'handler.
target
- L'oggetto target.
thisArg
- Il valore di
this
relativo alla chiamata. argumentsList
- La lista degli argomenti della chiamata.
Valore di ritorno
Il metodo apply
può restituire qualsiasi valore.
Descrizione
Il metodo handler.apply
è una trap per le chiamate a funzione.
Operazioni intercettate
Questa trap può intercettare le seguenti operazioni:
proxy(...args)
Function.prototype.apply()
eFunction.prototype.call()
Reflect.apply()
Invarianti
Se le seguenti invarianti non sono rispettate il proxy emetterà un TypeError:
- Lo stesso
target
deve essere un oggetto richiamabile, cioè deve essere un oggetto funzione.
Esempi
Il codice seguente intercetta una chiamata a funzione.
var p = new Proxy(function() {}, {
apply: function(target, thisArg, argumentsList) {
console.log('chiamato con: ' + argumentsList.join(', '));
return argumentsList[0] + argumentsList[1] + argumentsList[2];
}
});
console.log(p(1, 2, 3)); // "chiamato con: 1, 2, 3"
// 6
Specifiche
Specifica | Stato | Commenti |
---|---|---|
ECMAScript 2015 (6th Edition, ECMA-262) The definition of '[[Call]]' in that specification. |
Standard | Initial definition. |
ECMAScript (ECMA-262) The definition of '[[Call]]' in that specification. |
Living Standard |
Compatibilità browser
BCD tables only load in the browser
La tabella di compatibilità su questa pagina è generata a partire da dati strutturati. Se vuoi contribuire ai dati, fai un check out da https://github.com/mdn/browser-compat-data e mandaci una pull request.