Ответ
- Контекст (
this)
У обычной функцииthisдинамический (зависит от вызова), у стрелочной — лексический (берется из внешней области).
const obj = {
name: 'Test',
regular: function() { console.log(this.name) }, // 'Test'
arrow: () => console.log(this.name) // undefined (если не strict mode — window)
};
-
arguments
Обычная функция имеет псевдомассивarguments, стрелочная — нет. -
Использование с
new
Обычную можно вызывать как конструктор (new Func()), стрелочную — нельзя. -
Синтаксис
Стрелочные функции короче, особенно для однострочных выражений:
const sum = (a, b) => a + b; // return не нужен
- Привязка
super/prototype
У стрелочных нетprototype, они не подходят для методов класса, где нуженsuper.
Когда использовать:
- Стрелочные — для колбэков, сохранения контекста.
- Обычные — методы объектов/классов, конструкторы, функции с
arguments.