电竞比分网-中国电竞赛事及体育赛事平台

分享

Quick Tip: Calling JavaScript Methods on Other Objects

 燮羽 2010-11-27

Using Call and Apply

Here’s the scenario: we have two objects:

  1. var joe = {  
  2.     name : "Joe",  
  3.     greet : function (name) {  
  4.         alert(this.name + " says hello to " + name);  
  5.     }  
  6. };  
  7.   
  8. var jill = {  
  9.     name : "Jill"  
  10. };  

It’s pretty simple to get Joe to greet Jill:

  1. joe.greet("Jill");  

But how can we get Jill to greet Joe? She doesn’t have a greet method (and let’s assume we can’t / won’t / shouldn’t give her one). Well, because everything in JavaScript—including functions—is an object, everything can have a method, or a function that can be called from it. Functions are given two methods that allow you to call them in different contexts.

The context of a method is basically the object that will be this when the function is called. In our greetmethod, this refers to the object joe, because that’s what it is a part of.

Now, try this:

  1. joe.greet.call(jill, "Joe");  

The call method on JavaScript functions allows you to change the function’s context. The first parameter we pass in will be the new context: in this case, that’s jill. Subsequent parameters are the parameters to the function you’re calling. In this case, “Joe” will be passed to greet. If you run this, you’ll get an alert box with the message “Jill says hi to Joe.”

There’s also an apply method; the only difference is that it takes the parameters of the method as an array, rather than as raw parameters, a la the call method.

  1. joe.greet.call(jill, ["Joe"]);  

If you have a hard time remembering whether it’s call or apply that takes the array, remember that applyand array both start with ”a.”

Thanks for reading!

    本站是提供個人知識管理的網(wǎng)絡(luò)存儲空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點。請注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購買等信息,謹(jǐn)防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請點擊一鍵舉報。
    轉(zhuǎn)藏 分享 獻花(0

    0條評論

    發(fā)表

    請遵守用戶 評論公約

    類似文章 更多