首頁 > web前端 > js教程 > JS中定義函數的幾種方法

JS中定義函數的幾種方法

青灯夜游
發布: 2020-10-20 17:21:22
轉載
4373 人瀏覽過

JS中定義函數的幾種方法

你知道在 JavaScript 中建立函數有多少種方式嗎?以下這篇文章要為大家介紹一下在 JavaScript 中定義函數的幾種不同方法。有一定的參考價值,有需要的朋友可以參考一下,希望對大家有幫助。

1. 宣告函數##​​#

function sum(a, b) { return a + b; }
登入後複製

2.表達式函數

// 可以命名:
(function sum(a, b) { return a + b; });

// 也可匿名 (AVOID):
(function(a, b) { return a + b; });

// 也能分配给变量:
const sum = function sum(a, b) { return a + b; })
登入後複製

3.箭頭函數

// 一般形式:
(a, b) => { return a + b };

// 单参数,一行返回:
name => name.split(' ')

// 多参数,一行返回:
(a, b) => a + b

// 单参数,带函数体
name => { return name.split(' '); }
登入後複製

#4. 生成器函數

function *sum(a, b) { yield a + b; }
登入後複製

5. 非同步函數

async function sum(a, b) { return await a + b; }
登入後複製

#6. 建構子(AVOID)

new Function(‘a’, ‘b’, ‘return a + b;’);
登入後複製

#7.匯出函數

// 默认导出
export default function(a, b) { return a + b; };

// 命名导出
export function sum(a, b) { return a + b; };
登入後複製

#8. 物件屬性函數
// 一般形式:
const object = {
  sum: function(a, b) { return a + b; },
};

// 简写:
const object = {
  sum(a, b) { return a + b; },
};
登入後複製

9. 物件動態屬性函數

const functionName = "sum";
const object = {
  [functionName]: function(a, b) { return a + b; },
};
登入後複製

10. 物件屬性的Getter/Setter 函數

// 一般形式:
const object = {
  get answer { return 42; },
  set answer(value) { /* 一些操作value的代码 */ },
};

//  使用 defineProperty
const obj = {};
Object.defineProperty(obj, "answer", {
  get() { return 42; },
  set(value) { /* 一些操作value的代码 */ },
});
登入後複製

11. 物件動態屬性的Getter/Setter 函數

const functionName = "answer";
const object = {
  get [functionName]() { return 42; },
  set [functionName](value) { /* 一些操作value的代码 */ },
};
登入後複製

12. 類別方法函數

class Compute {
  // 一般形式:
  sum(a, b) { return a + b; }
}

class Compute {
  // 静态:
  static sum(a, b) { return a + b; };
}
登入後複製

13. 類別屬性函數

class Compute {
  // 一般形式:
  sum = function (a, b) { return a + b; };
}class Compute {
  // 静态:
  static sum = function(a, b) { return a + b; };
}
登入後複製

#14. 類別私有函數

class Compute {
  // 一般形式:
  #sum(a, b) {
    return a + b;
  }  // 静态:
  static #sum(a, b) {
    return a + b;
  }
}
登入後複製
總結

如果你把這些方式中的某幾個結合起來,還會有更多的可能性。 你知道還有哪些方法嗎,請留言告訴我。

相關免費學習推薦:js影片教學

#

以上是JS中定義函數的幾種方法的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:segmentfault.com
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板