国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > 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

以上所述就是本文的全部內容了,希望大家能夠喜歡。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 专栏| 邯郸市| 威信县| 长沙市| 基隆市| 双鸭山市| 汕尾市| 金湖县| 且末县| 亳州市| 资源县| 乌拉特中旗| 平和县| 泸溪县| 施甸县| 芷江| 唐海县| 图片| 彝良县| 罗定市| 毕节市| 剑阁县| 南江县| 荣昌县| 江西省| 天峨县| 大同市| 长寿区| 文水县| 元谋县| 嵊州市| 苍溪县| 威信县| 乌拉特前旗| 东阳市| 石景山区| 平安县| 翁源县| 盐山县| 英吉沙县| 凭祥市|