JavaScript handler.ownKeys() method in JavaScript is a trap for Reflect.ownKeys() method and this method returns an enumerable object.
Syntax:
const p = new Proxy(target, { ownKeys: function(target) { } });
Parameters: This method accepts a single parameter as mentioned above and described below:
- target: This parameter holds the target object.
Return value: This method always returns an enumerable object.
Below examples illustrate the handler.ownKeys() method in JavaScript:
Example 1: This example returns the keys of the object using the handler.ownKeys() method in JavaScript.
const monster1 = { prop1: 253,
prop2: "Geeks" ,
prop3: 0101011
} const handler1 = { ownKeys(target) {
return Reflect.ownKeys(target)
}
} const proxy = new Proxy(monster1, handler1);
for (let key of Object.keys(proxy)) {
console.log(key);
} |
Output:
prop1 prop2 prop3
Example 2: This example returns the keys of the object using the handler.ownKeys() method in JavaScript.
let proxy1 = new Proxy({}, {
ownKeys: function (target) {
console.log( "handler.ownKeys() Method" );
return [ 'Geeks1' , 'Geeks2' , 'Geeks3' ];
}
}); console.log(Object.getOwnPropertyNames(proxy1)); |
Output:
handler.ownKeys() Method Geeks1,Geeks2,Geeks3
Supported Browsers: The browsers supported by handler.ownKeys() method are listed below:
- Google Chrome 49 and above
- Edge 12 and above
- Firefox 18 and above
- Opera 36 and above
- Safari 10 and above
We have a complete list of Javascript Proxy/handler methods, to check those go through the Javascript Proxy/handler Reference article.