The method Reflect.apply
is just a better and more meaningful way to do Function.prototype.apply
. In other words, it allows you to call the given function using a specified context (this
argument) on an array of arguments. Here is an example:
let person = {
name: "John",
speak(city) {
console.log(`Hi. I am ${this.name}. I am calling from ${city}.`);
},
};
let someone = {
name: "Jack",
};
person.speak("Houston");
// Hi. I am John. I am calling from Houston.
Reflect.apply(person.speak, someone, ["Boston"]);
// Hi. I am Jack. I am calling from Boston.
person.speak.apply(someone, ["Boston"]); // the same
Function.prototype.apply.call(person.speak, someone, ["Boston"]); // the same
As I said in an earlier post, the Reflect
object gathers all functionality related to reflection in one place. This makes it possible to write neater and more readable code.
Last line is really interesting...
Function.prototype.apply.call
Was not aware it works that way. Actually:
Function.prototype.call === Function.prototype.bind.call.apply.bind.call
So it seem that
Function.prototype
functions (Function.prototype.bind
,Function.prototype.call
, etc.) do have object linkage toFunction.prototype
object. We can even access such linkage. See here:Function.prototype.apply.__proto__ === Function.prototype
That's why we can chain it deeply. Really interesting. Also was not aware of such Reflect feature. Thanks for sharing.
Thank you for your informative reply.
I didn't understood
Informative post.
Hi I'm duma, I'm calling from Indonesia :)
Good post, thanks for sharing this post.
nice post bro
Have a nice day sir, Stay safe.
sir as a new steemers i want your help by my post
Looks like i still need to learn a lot of programming :)
but many thanks for sharing it
I am not so good in javascript but this is informative 😊
great post, ghasemkiani as usual!
person.speak("thanks for the post, this will Reflect in future coding of mine");
مشتی ساپورت ♥
another interesting information about reflect , thanks
cool post. i am also a js developer from time to time
it's very informative post.
That's a great gaming programming...Keep it up...
it so helpful post for us......
thanks for sharing.
well thanks for sharing .. learning have a nice day bro
programing is a language of computer you input this his language and its output your language
now its a very important in every sphere
carry on
That's a great and outstanding programming ..Resteemit done..
Thanks for sharing this post.
I appreciate your every post ..Best of luck.
Thank you for sharing and teaching others sir..
Thanks for giving us a new topic.It is an educative value for us.We can get many concept about javascript,programming & so on.
Thanks
@Ressteem,upvote & follow done.
This nice post iappreciate your programming thanks for sharing this technology..Carry on..
I always follow your post everything is good if any time visit my blog @mamaathiyya
Thanks for this post, very informative i hope you keep sharing with us all your knowledge
Upvote and resteemit...
Like back
javascript is a advance programming language . i try c language as a begainer
Good post..Keep it up..
Carry on your activitys
Thanks for share JavaScript
Your information is very useful, the work you do is very meaningful, I really appreciate post @ghasemkiani
nice post...thanks for share
This is my favorite javascript...
well wrote dear @ghasemkiani
nice program. i like it
@ghasemkiani Good tutorial. I just love this. Thanks for sharing.
you are a good javascript programmer. well done @ghasemkiani
Nice post sir.
very well post dear friend @ghasemkiani
great
Nice Post ..
Followed you..
add-on on the Reflect post, thanks,
its the bleesing of science.and
important also...
carry on please.
i will wait for your next info....
its a great info.i really praise your activity..
many thanks for sharing us...