Ответ
-
Контекст (
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.