Лекция
Привет, сегодня поговорим про функция - это значение, обещаю рассказать все что знаю. Для того чтобы лучше понимать что такое функция - это значение , настоятельно рекомендую прочитать все из категории Выполнение скриптов на стороне клиента JavaScript, jqvery, JS фреймворки (Frontend).
В этом разделе мы познакомимся c важными особенностями функций в JavaScript, а также с тремя способами объявить функцию.
В JavaScript функция является значением, таким же как строка или число.
Объявление создает функцию и записывает ссылку на нее в переменную.
Как и любое значение, функцию можно вывести, вот так:
1 |
function sayHi() { |
2 |
alert( 'Привет' ); |
3 |
} |
4 |
5 |
alert(sayHi); // выведет код функции |
Здесь выводится не результат работы функции sayHi()
(кстати, чему он равен?.. правильно,undefined
, т.к. нет return
), а сама функция, т.е. ее код.
Функция — не просто значение, это объект.
В него можно даже записать свойство:
1 |
function sayHi() { } |
2 |
3 |
sayHi.test = 5; |
4 |
5 |
alert(sayHi.test); // 5 |
Используется эта возможность достаточно редко.
Функцию можно скопировать в другую переменную.
1 |
function sayHi(person) { |
2 |
alert( 'Привет, ' + person); |
3 |
} |
4 |
5 |
var func = sayHi; |
6 |
7 |
alert(func); // выведет код функции |
При этом, так как функция — это объект, то и копируется она «по ссылке».
То есть, сама функция лежит где-то в памяти, а переменная содержит «адрес», где она находится. Об этом говорит сайт https://intellect.icu . При присваивании func = sayHi
копируется этот адрес, обе переменные начинают указывать на одно и то же «место в памяти», где находится функция.
После копирования ее можно вызывать:
1 |
function sayHi(person) { |
2 |
alert( 'Привет, ' + person); |
3 |
} |
4 |
5 |
var func = sayHi; |
6 |
7 |
func( 'Вася' ); // выведет 'Привет, Вася' |
8 |
9 |
sayHi( 'Маша' ); // и так по-прежнему работает: 'Привет, Маша' |
Заметим еще раз, что обращение вида alert(func)
отличается от alert( func() )
. В первом случае выводится функция (ее код), во втором — эта функция вызывается, и выведен будет уже ее результат.
К сожалению, в одной статье не просто дать все знания про функция - это значение. Но я - старался. Если ты проявишь интерес к раскрытию подробностей,я обязательно напишу продолжение! Надеюсь, что теперь ты понял что такое функция - это значение и для чего все это нужно, а если не понял, или есть замечания, то не стесняйся, пиши или спрашивай в комментариях, с удовольствием отвечу. Для того чтобы глубже понять настоятельно рекомендую изучить всю информацию из категории Выполнение скриптов на стороне клиента JavaScript, jqvery, JS фреймворки (Frontend)
Из статьи мы узнали кратко, но содержательно про функция - это значение
Комментарии
Оставить комментарий
Выполнение скриптов на стороне клиента JavaScript, jqvery, JS фреймворки (Frontend)
Термины: Выполнение скриптов на стороне клиента JavaScript, jqvery, JS фреймворки (Frontend)