Форум программистов, компьютерный форум, киберфорум
JavaScript для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.60/5: Рейтинг темы: голосов - 5, средняя оценка - 4.60
0 / 0 / 0
Регистрация: 06.12.2017
Сообщений: 7

Объясните, пожалуйста, логику работы кода

06.12.2017, 20:59. Показов 1163. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Пожалуйста, объясните логику этого примера, не могу совсем разобраться.
Сначала мы вызываем функцию setupHelp(), у нас в ней есть массив объектов, есть счетчик. В счетчике мы от i=0 до i=2 записываем в переменную item объекты из массива helpText. Дальше строка описывает действие, которое запускает функцию makeHelpCallback(), в данном случае onfocus. Затем мы вызываем функцию makeHelpCallback(), которая запускает функцию showHelp(). Вопросы:
-почему это работает?
-как счетчик запоминает (и куда) что делать, если мы взяли в фокус поле ввода? Разве он не должен проработать от 0 до 2 и забыться?
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
function showHelp(help) {
  document.getElementById('help').innerHTML = help;
}
 
function makeHelpCallback(help) {
  return function() {
    showHelp(help);
  };
}
 
function setupHelp() {
  var helpText = [
      {'id': 'email', 'help': 'Ваш адрес e-mail'},
      {'id': 'name', 'help': 'Ваше полное имя'},
      {'id': 'age', 'help': 'Ваш возраст (Вам должно быть больше 16)'}
    ];
 
  for (var i = 0; i < helpText.length; i++) {
    var item = helpText[i];
    document.getElementById(item.id).onfocus = makeHelpCallback(item.help);
  }
}
 
setupHelp();
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
06.12.2017, 20:59
Ответы с готовыми решениями:

Объясните принцип решения кода на словах, пожалуйста
var poly = 1221; var ylop = 0; var isPalindrome = false; for (var i = poly; i &gt; 0; i /= 10) { ylop+= i % 10; if (i &gt;=...

Объясните пожалуйста суть кода
var x = a.match(/title=&quot;*(-?+)/)*1; var y = b.match(/title=&quot;*(-?+)/)*1; return ((x &lt; y) ? -1 : ((x &gt; y) ? 1 : 0));

Объясните пожалуйста отрывок кода
Всем привет, (//.test(field)) увидел такой кусок кода в книге, но никак не могу разобраться с ним. Я понимаю его так: test в...

4
Эксперт JS
2463 / 1769 / 625
Регистрация: 11.07.2016
Сообщений: 4,067
07.12.2017, 10:03
Цитата Сообщение от ArtyomZaitsev Посмотреть сообщение
почему это работает?
А почему оно должно не работать?
Цитата Сообщение от ArtyomZaitsev Посмотреть сообщение
как счетчик запоминает (и куда) что делать, если мы взяли в фокус поле ввода? Разве он не должен проработать от 0 до 2 и забыться?
Вы допустили ошибку в своих рассуждениях.
Цитата Сообщение от ArtyomZaitsev Посмотреть сообщение
строка описывает действие, которое запускает функцию makeHelpCallback(), в данном случае onfocus
Не верно. Когда отрабатывает цикл, он навешивает на 3 разных элемента событие onfocus. Обратите внимание, что данному событию присваивается не функция makeHelpCallback, а результат работы функции makeHelpCallback(item.help), которая возвращает другую анонимную функцию (строка 6). То есть функция makeHelpCallback() отрабатывает не при срабатывании события onfocus, как вы предполагаете, а при запуске setupHelp(). То есть если развернуть цикл, получится следующее:
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
function setupHelp() {
  var helpText = [
      {'id': 'email', 'help': 'Ваш адрес e-mail'},
      {'id': 'name', 'help': 'Ваше полное имя'},
      {'id': 'age', 'help': 'Ваш возраст (Вам должно быть больше 16)'}
    ];
 
  var item = helpText[0];
  document.getElementById(item.id).onfocus = function() { // Элемент с id="email"
    showHelp(item.help); // showHelp('Ваш адрес e-mail');
  };
 
  var item = helpText[1];
  document.getElementById(item.id).onfocus = function() { // Элемент с id="name"
    showHelp(item.help); // showHelp('Ваше полное имя');
  };
 
  var item = helpText[2];
  document.getElementById(item.id).onfocus = function() { // Элемент с id="age"
    showHelp(item.help); // showHelp('Ваш возраст (Вам должно быть больше 16)');
  };
}
0
566 / 465 / 183
Регистрация: 14.10.2017
Сообщений: 1,259
07.12.2017, 11:50
Balanaar, а у меня onfocus почему-то не присваивается в этой строке
JavaScript
1
document.getElementById(item.id).onfocus = makeHelpCallback(item.help);
если же убрать аргумент из функции,то присваивается,но теряется контекст
JavaScript
1
document.getElementById(item.id).onfocus = makeHelpCallback;
HTML5
1
2
3
4
    <p id="email">email</p>
    <p id="name">name</p>
    <p id="age">age</p>
    <p id="help">help</p>
по идее,в последний параграф должно выводиться либо 'Ваш адрес e-mail', либо 'Ваше полное имя', либо 'Ваш возраст (Вам должно быть больше 16)'
0
Эксперт JS
2463 / 1769 / 625
Регистрация: 11.07.2016
Сообщений: 4,067
07.12.2017, 12:01
klopp, элемент <p> не может вызвать событие фокуса. Попробуйте <input>. Либо замените на событие onclick.
2
0 / 0 / 0
Регистрация: 06.12.2017
Сообщений: 7
07.12.2017, 19:32  [ТС]
спасибо
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
07.12.2017, 19:32
Помогаю со студенческими работами здесь

Объясните, пожалуйста, в каком порядке Java-машина читает код и логику работы
Объясните, пожалуйста, в каком порядке Java-машина читает код и логику работы. Для меня выглядит так, как будто не хватает одного...

Объясните пожалуйста принцип работы кода
Доброго времени суток, объясните пожалуйста принцип работы кода. Это шифровальщик и дешифровальщик по методу Виженера. #include...

Пожалуйста объясните логику действий!
Всем привет ребята. Только начал изучать условные операторы и в принципе понимаю как они работают. Но вот стоит задача написать программы...

Объясните логику кода
Здравствуйте! Прошу помощи у вас - объясните, пожалуйста, логику небольшого фрагмента кода. Что он должен делать и как, действителен...

Объясните логику работы программы
public static boolean getAnswer ( int array){ if (array.length &lt; 2) return false; for (int i = 0; i &lt; array.length - 1;...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru