Help with JS and functions parameters

后端 未结 6 1753
佛祖请我去吃肉
佛祖请我去吃肉 2021-01-31 19:26

Does JS support two functions with the same name and different parameters ?

function f1(a, b)
{
// a and b are numbers
}

function f1(a, b, c)
{
// a is a string         


        
相关标签:
6条回答
  • 2021-01-31 19:34

    JavaScript doesn't support what you would call in other languages method overloading, but there are multiple workarounds, like using the arguments object, to check with how many arguments a function has been invoked:

    function f1(a, b, c) {
      if (arguments.length == 2) {
        // f1 called with two arguments
      } else if (arguments.length == 3) {
        // f1 called with three arguments
      }
    }
    

    Additionally you could type-check your arguments, for Number and String primitives is safe to use the typeof operator:

    function f1(a, b, c) {
      if (typeof a == 'number' && typeof b == 'number') {
        // a and b are numbers
      } else if (typeof a == 'string' && typeof b == 'number' &&
                 typeof c == 'number') {
        // a is a string, b and c are numbers
      }
    }
    

    And there are much more sophisticated techniques like the one in the following article, that takes advantage of some JavaScript language features like closures, function application, etc, to mimic method overloading:

    • JavaScript method overloading
    0 讨论(0)
  • 2021-01-31 19:37

    You can also use instanceof, example with basic polymorphism.

    First create a superclass (ball)

    // superclass
    function Ball() {
        this.play = function() {
            alert("Ball throw");
        };
    }
    

    and now for some subclasses (types of balls)

    // subclass
    function Basketball() {
        this.play = function() {
            alert("basketball throw");
        };
    }
    // subclass
    function Soccerball() {
        this.play = function() {
            alert("soccer ball kick/throw");
            console.debug("here");
        };
    }
    // subclass
    function Baseball() {
        this.play = function() {
            alert("strike 3 you're out");
            console.debug("here");
        };
    }
    

    Give them Ball functionality, aka set their superclass via prototype

    // set subclass functionality
    Basketball.prototype = new Ball();
    Soccerball.prototype = new Ball();
    Baseball.prototype = new Ball();
    

    Some polymorphism (create a bunch of balls and play with them all, but play based on type)

    var bunchOfBalls = [new Baseball(), new Soccerball(), new Basketball()];
    for (var i = 0; i < bunchOfBalls.length; i++) {
        bunchOfBalls[i].play();
    }
    

    Now write a function that takes a ball but only want to to work for specific type of balls (mimic function overloading, more or less)

    //overloading dependent upon type
    function BasketbalOrBaseballOnlyPlay(aBall) {
        if (aBall instanceof Basketball) {
            //special basketball function
        }
        if (aBall instanceof Baseball) {
            //special baseball function
        }
    
    }
    

    If aBall is a Basketball so aBall = new Basketball(); then aBall instanceof Basketball would return true for Basketball and false for baseball but true for Ball.

    So aBall instanceof Ball would return true because a Basketball is a Ball.

    See code live at http://jsfiddle.net/kLCPB/

    0 讨论(0)
  • 2021-01-31 19:40

    No, you can't use function overloading in JS.

    But, you can declare just the version with 3 parameters, and then check whether the third argument === undefined, and provide differentiated behaviour on that basis.

    0 讨论(0)
  • 2021-01-31 19:40

    Javascript only uses the function that was defined last.

    http://weblogs.asp.net/jgalloway/archive/2005/10/02/426345.aspx

    You will need to implement your own logic inside the function to determine which parameters were passed in.

    0 讨论(0)
  • 2021-01-31 19:48

    No, that will not work, only the 2nd function will be defined on your page. Here's a source.

    0 讨论(0)
  • 2021-01-31 19:52

    No you can't do that ... unless it is OK with you to only have your last definition hold.

    0 讨论(0)
提交回复
热议问题