麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 語言 > JavaScript > 正文

詳細分析JavaScript函數定義

2024-05-06 16:23:15
字體:
來源:轉載
供稿:網友

這篇文章主要給大家詳細分析了JavaScript函數定義的相關資料,需要的朋友可以參考下

函數

幾個要點:

a).函數是javascript中的一等公民 (重要性)

b).函數是一個對象

c).函數定義了一個獨立的變量作用域

定義方式

a)命名函數:

除非在另一個函數內部定義,否則,命名函數是全局的。

 

 
  1. // 全局的命名函數 
  2. function add(x, y) { 
  3. return x + y; 
  4. console.info(add(100, 200)); //300 

b)匿名函數:

匿名函數通常賦值給一個變量,再通過變量調用。

 

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

匿名函數適用于以下這種 “立即執行的匿名函數” 的情況:

 

 
  1. console.info( 
  2. function (x, y) { 
  3. return x + y; 
  4. }(100, 200) //立即調用 
  5. ); 

C)定義方式影響代碼執行效果

命名函數可以先使用,再定義

 

 
  1. console.info(sum(10, 10)); 
  2. function sum(num1, num2) { 
  3. return num1 + num2; 

匿名函數必須先定義,再使用

 

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

函數返回值:

用return 生成返回值.如沒有return ,則函數返回undefined

 

 
  1. function func() { 
  2. console.info(func()); //undefined 
  3. function func2() { 
  4. return//空的返回語句 
  5. console.info(func2()); //undefined 

return里藏著的坑:

 

 
  1. var func = function (x, y) { 
  2. var sum = x + y; 
  3. return { 
  4. value : sum 

這么寫沒有問題: 調用 func(5,5) 返回的是 Object {value: 10}

然而:

 

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

return 后面跟著個回車換行的話,

調用 func(5,5) 顯示的是 undefined

編輯器幫我們在return后加了個分號; 然而在這情況下并沒有什么卵用。

函數即對象:

 

 
  1. function add(x, y) { 
  2. return x + y; 
  3. console.info(add(100, 200)); //300 
  4. var other = add; //other和add引用同一函數對象 
  5. console.info(other(300, 400)); //700 
  6. console.info(typeof other); //function 
  7. console.info(add === other); //true 

嵌套定義的函數:

在函數內部,可以定義另一個函數。

 

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

訪問外部變量:

內部函數可以訪問外部的變量與參數。

 

 
  1. var globalStr = 'globalStr'
  2. function outerFunc2(argu) { 
  3. var localVar = 100; 
  4. function innerFunc2() { 
  5. localVar++; 
  6. console.info(argu + ":" + localVar + ":" + globalStr); 
  7. innerFunc2(); //hello:101:globalStr 
  8. outerFunc2("hello"); 

返回函數的函數:

因為函數是對象,所以可以作為返回值。

 

 
  1. function outerFunc(x) { 
  2. var y = 100; 
  3. return function innerFunc() { 
  4. console.info(x + y); 
  5. outerFunc(10)(); //110 

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 毛片大全在线观看 | 韩国十九禁高潮床戏在线观看 | 精品在线观看一区二区三区 | 色综合久久久久久久久久久 | 日日影视 | 嗯~啊~弄嗯~啊h高潮视频 | 精品亚洲视频在线 | 国产精品久久久久久久久久久久久久久 | 干少妇av | 一级成人欧美一区在线观看 | 在线视频观看成人 | 国产成人av免费 | 91亚洲精品一区二区福利 | 久久99精品久久久久久秒播放器 | 久久久久久精 | 九九热精品视频在线 | 国产精品视频在线观看免费 | 免费观看一区二区三区视频 | h视频在线播放 | www久| 精品一区二区电影 | 日本网站在线播放 | h色网站在线观看 | 深夜激情视频 | 成人免费一区二区三区在线观看 | 美女在线观看视频一区二区 | 欧美成人精品一区二区 | 成人免费网站在线观看 | 中文字幕欧美日韩 | 日本高清在线免费 | 国内精品国产三级国产a久久 | 亚洲精品成人久久久 | 久草在线新视觉 | 免费观看视频在线观看 | 日本成人二区 | 国产亚洲精品综合一区91 | 大胆在线日本aⅴ免费视频 美国黄色毛片女人性生活片 | 韩国一大片a毛片 | 国产成人高清在线观看 | 久久精品一区二区三区国产主播 | 成年免费视频黄网站在线观看 |