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

JS中定義函數的幾種方法

青灯夜游
青灯夜游轉載
2020-10-20 17:19:334402瀏覽

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刪除