Skip to content

Instantly share code, notes, and snippets.

@myshov
Last active August 19, 2024 12:23
Show Gist options
  • Save myshov/05800f083a0afce56e0f782314a103eb to your computer and use it in GitHub Desktop.
Save myshov/05800f083a0afce56e0f782314a103eb to your computer and use it in GitHub Desktop.
11 Ways to Invoke a Function
console.log(1);
(_ => console.log(2))();
eval('console.log(3);');
console.log.call(null, 4);
console.log.apply(null, [5]);
new Function('console.log(6)')();
Reflect.apply(console.log, null, [7])
Reflect.construct(function(){console.log(8)}, []);
Function.prototype.apply.call(console.log, null, [9]);
Function.prototype.call.call(console.log, null, 10);
new (require('vm').Script)('console.log(11)').runInThisContext();
@gonzaloruizdevilla
Copy link

with double colon bind operator:
console::(console.log)(0)

@jorrit
Copy link

jorrit commented Apr 11, 2017

Promise.resolve(19).then(console.log)

@guillermo
Copy link

guillermo commented Jun 18, 2017

console["log"](9)

@franciscop
Copy link

Using Proxy (not yet mentioned) you can make accessing, setting, etc a property to be an actual function call:

const log = new Proxy(console.log, {
  get: (orig, key) => orig(key)
});

log[11];

Based on this awesome/awful feature I created a little monster:

const buttons = dom.button.html;
dom.a.html = 'Hello world';

@jonbri
Copy link

jonbri commented Jun 19, 2017

@o0101
Copy link

o0101 commented Jun 19, 2017

I'm a fan of this one:

(class { [console.log(1)](){} })
({[console.log(1)](){}})
(function z( a = console.log(1) ){})()
[...{[Symbol.iterator](){return {next(){ return {done:console.log(1)}}}}}]; // hehe
try{[1,2,3][~~(Math.random()*4)].toString()}catch(e){console.log(12)}; // nondeterministically run console.log 

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment