-
Notifications
You must be signed in to change notification settings - Fork 16
arrowFunction
В сигнатуре стрелочной функции нет слова function
( параметры ) => { тело функции }
☕
var res = ( x, y ) => x * y
res ( 2, 5 )🔳 Если тело функции состоит из одной операции, фигурные скобки можно опустить
( name = "user" ) => console.info ( "Hi, " + name )🔳 Если у функции всего один формальный параметр, круглые скобки можно опустить
name => console.info ( "Hi, " + name )🔳 При отсутствии формальных параметров круглые скобки обязательны
() => console.info ( "Hi, user" )🔳 Если тело функции состоит из одного выражения, значение которого возвращает функция, оператор return не используется
var res = function ( x, y ) { return x * y }var res = ( x, y ) => x * y🔳 Операторы ветвления кода ( кроме тернарного оператора ) и операторы цикла нужно заключать в фигурные скобки
() => {
for ( var i = 0; i < 5; i++ )
console.log ( i )
}var answerArrow = question => {
switch ( question ) {
case "who":
return "student"
case "what":
return "develop"
case "where":
return "Kharkiv"
default:
return "I don't undestand your question"
}
}var answerArrow = question =>
question === "who" ? "Irina" :
question === "what" ? "develop" :
question === "where" ? "Kharkiv" :
"I don't undestand your question"У стрелочных функций нет объекта prototype
var arrowFunc = () => {}
console.dir ( arrowFunc )
const usualFunc = function () {}
console.dir ( usualFunc )▼ arrowFunc ()
arguments: (...)
caller: (...)
length: 0
name: "func"
► __proto__: ƒ ()▼ ƒ usualFunc ()
arguments: null
caller: null
length: 0
name: "usualFunc"
► prototype: {constructor: ƒ}
► __proto__: ƒ ()new
var obj = new arrowFunc()будет сгенерировано исключение:
🛑 TypeError: arrowFunc is not a constructor
У стрелочных функций нет объекта arguments
При попытке обратиться к объекту arguments из стрелочной функции будет сгенерировано исключение ( ReferenceError )
☝️ Если стрелочная функция объявлена внутри обычной функции, то переменные контекста родительской функции будут доступны для стрелочной функции ( цепочка областей видимости ), поэтому внутри нее будет доступен объект arguments родительской функции
☕
function testArguments () {
var arrowFunc = () => console.log ( arguments )
arrowFunc ()
}
testArguments ( 5, false )В результате работы кода в консоль будет выведен объект arguments функции testArguments
У стрелочных функций контекст вызова всегда будет контекстом, в котором функция была объявлена
Изменить контекст вызова стрелочной функции невозможно
Можно сказать, что у стрелочных функций "врожденный" контекст вызова
var obj = {
test: () => console.log ( this )
}
obj.test() // windowВ случае, если экземпляр объекта создан с помощью конструктора, использование стрелочных функций в публичных методах объекта гарантирует, что this будет всегда ссылаться на экземпляр
document.querySelector ( "button" )
.onclick =
event => console.log ( event.type, this )this будет указывать на глобальный объект window
document.querySelector ( "button" )
.onmouseover = function ( event ) {
console.log ( event.type, this )
}this будет указывать на элемент button
В примере ниже экземпляр x создан с помощью конструктора Constr
Публичный метод arrowFunc() объявлен с помощью стрелочной функции
Публичный метод usialFunc() объявлен с помощью обычной функции
При передаче метода arrowFunc() переменной z:
var z = x.arrowFuncконтекст сохраняется,
а при передаче метода usialFunc() переменной w:
var w = x.usialFuncконтекст меняется, и this уже указывает на глобальный объект window
Таким образом, у стрелочной функции контекст, в котором она была создана, привязан к функции и не может быть утерян
У обычной функции контекст вызова может отличаться от контекста, в котором она была создана
Еще один пример наглядно показывает, что изменить контекст вызова стрелочной функции, определенный при ее создании, нельзя
Объявим две функции в глобальной области видимости:
var arrowFunc = () => console.log ( this )
var usialFunc = function () {
console.log ( this )
}Теперь создадим объект obj с единственным свойством name:
obj = { name: "sample" }и добавим ему методы testArrow и testUsial:
obj.testArrow = arrowFunc
obj.testUsial = usialFuncТеперь вызовем оба метода
obj.testArrow ()
obj.testUsial ()Как видим, несмотря на то, что вызов осуществляется в контексте объекта obj, testArrow "работает" в контексте, в котором была создана функция arrowFunc, т.е. в глобальном контексте
Что касается метода testUsial, то он работает в контексте вызова, т.е. в контексте объекта obj
© Irina H.Fylyppova 2018
Использование данных материалов или любой их части коммерческими школами ( курсами ) является нарушением авторских прав
| 1 | 2 | 3 | 4 | 5 |
| 6 | 7 | 8 | 9 | 10 |
| 11 | 12 | 13 | 14 | 15 |
| 16 | 17 | 18 | 19 |
| ⏬ |
|---|
- Блок-схема алгоритма
- Developer Tools
- Chrome DevTools
- Переменные
- Оператор typeof
- Структуры данных
- Операторы присваивания
- Логические выражения
- Условные операторы
- Инкремент
- Свойство length
- Оператор цикла for
- UTF-8
Homework
- Приведение типов
- NaN | null | Infinity
- BigInt (ES10)
- Функции
- Методы
- Методы строк
- Методы массивов
- Date ()
Самостоятельная работа
Практика (XSS)
Homework
- Циклы while и do...while
- Циклы for...of и for...in
- Параметры по умолчанию
- Объект function
Практика
Homework
- Нативные и host-объекты
- Литерал объекта
- Унаследованные свойства
- Конструктор
- Модель наследования
- Публичные и приватные свойства
- Оператор in
1
Homework
- Итерирующие методы массивов
- Тестирование производительности
- SHA
Homework
- Размеры и прокрутка элемента
- Event Loop
- async | await
- API
- REST | HATEOAS
- status codes
JSON placeholder-
JSON server
fake chat
Homework
- strict mode
- Вычисляемые имена свойств
- Краткий синтаксис методов
- Краткий литерал объекта
- Классы
Homework
- :not(:defined)
- Shadow DOM
- Custom elements
- Lifecycle hooks
- whenDefined
- <template>
- slot
1
2
3
Homework
- npm
- webpack
Упражнение 1- ES6 модули
Упражнение 2- --mode | --watch
Упражнение 3
Упражнение 4
Упражнение 5
Упражнение 6
Упражнение 7
Упражнение 8
Homework
| ⏫ |
|---|

Дополнительно
Справочная инфо
Git Bush
TCP/IP
Коды символов