首页 > 编程 > JavaScript > 正文

详细分析JavaScript函数定义

2019-11-20 12:02:22
字体:
来源:转载
供稿:网友

函数

几个要点:

                a).函数是javascript中的一等公民 (重要性)
                b).函数是一个对象
                c).函数定义了一个独立的变量作用域

定义方式

a)命名函数:

          除非在另一个函数内部定义,否则,命名函数是全局的。 

      // 全局的命名函数  function add(x, y) {    return x + y;  }  console.info(add(100, 200));  //300

b)匿名函数:   

            匿名函数通常赋值给一个变量,再通过变量调用。

    var func = function (x, y) {      return x + y;    }    console.info(func(5, 2)); //7

            匿名函数适用于以下这种 “立即执行的匿名函数” 的情况:

    console.info(      function (x, y) {            return x + y;          }(100, 200)  //立即调用        );

C)定义方式影响代码执行效果

                命名函数可以先使用,再定义

    console.info(sum(10, 10));    function sum(num1, num2) {      return num1 + num2;    }

              匿名函数必须先定义,再使用

    //console.info(sumFunc(10, 10));  //Uncaught TypeError: Property 'sumFunc' of object [object Object] is not a function     var sumFunc = function (num1, num2) {      return num1 + num2;    };    console.info(sumFunc(10, 10));

函数返回值:

                 用return 生成返回值.如没有return ,则函数返回undefined

 function func() { } console.info(func()); //undefined function func2() {   return; //空的返回语句 } console.info(func2()); //undefined

return里藏着的坑:

 var func = function (x, y) {   var sum = x + y;   return {     value : sum   } }

                   这么写没有问题:   调用 func(5,5)    返回的是 Object {value: 10}

                   然而: 

  var func = function (x, y) {    var sum = x + y;    return    {      value: sum    };  }  console.info(func(5,5)); //undefined

                   return 后面跟着个回车换行的话,
                   调用 func(5,5)    显示的是 undefined
                   编辑器帮我们在return后加了个分号;   然而在这情况下并没有什么卵用。

函数即对象:

  function add(x, y) {    return x + y;  }  console.info(add(100, 200)); //300  var other = add; //other和add引用同一函数对象  console.info(other(300, 400)); //700  console.info(typeof other);  //function  console.info(add === other); //true

嵌套定义的函数:

                  在函数内部,可以定义另一个函数。

  function outerFunc(a, b) {    function innerFunc(x) {      return x * x;    }    return Math.sqrt(innerFunc(a) + innerFunc(b));  }  console.info(outerFunc(3, 4)); //5

访问外部变量:

             内部函数可以访问外部的变量与参数。

 var globalStr = 'globalStr'; function outerFunc2(argu) {   var localVar = 100;   function innerFunc2() {     localVar++;     console.info(argu + ":" + localVar + ":" + globalStr);   }   innerFunc2(); //hello:101:globalStr } outerFunc2("hello");

返回函数的函数:

               因为函数是对象,所以可以作为返回值。

  function outerFunc(x) {    var y = 100;    return function innerFunc() {      console.info(x + y);    }  }  outerFunc(10)(); //110

以上所述就是本文的全部内容了,希望大家能够喜欢。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表