Гость
Целевая тема:
Создать новую тему:
Автор:
Форумы / HTML, JavaScript, VBScript, CSS [игнор отключен] [закрыт для гостей] / Передать значение между вызовами / 5 сообщений из 5, страница 1 из 1
04.07.2019, 22:53
    #39834095
Alibek B
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Передать значение между вызовами
Есть примерно такой код:
Код: 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.
25.
26.
27.
28.
29.
30.
31.
32.
33.
34.
35.
36.
37.
38.
39.
40.
41.
42.
43.
44.
45.
46.
47.
48.
49.
function form_send()
{
	var frm = document.forms.auth;
	...
	event.preventDefault();
	var login = frm.login.value;
	var password = frm.password.value;
	var hash = hexMD5(password);
	var auth = {"username": login, "hash": hash};
	http('/auth', auth,
		function(data)
		{
			...
			http('/login', {"username": login, "password": password},
				function(data)
				{
					...
				},
				function(err)
				{
					...
				}
			);
		},
		function(err)
		{
			...
		}
	);
}

function http(path, data, success, fail)
{
	var xhr = new XMLHttpRequest();
	var uri = '...';
	...
	xhr.open("POST", uri, true);
	xhr.onreadystatechange = function() {
		if (this.readyState != 4) return;
		if (this.status != 200)
		{
			fail('#'+this.status + ' ' + this.statusText);
			return;
		}
		success(res)
		return res;
	};
	xhr.send(data);
}


При отправке формы скрипт вначале отправляет auth-запрос, передавая в него логин и хеш пароля, а затем при успешном выполнении auth-запроса скрипт отправляет login-запрос, передавая в него логин и пароль в чистом виде.
Приведенный выше пример нерабочий, так как во внутренней функции нет переменных login и password.
Как их лучше получить в данном случае? Просто еще раз получить из полей формы? Или передать в аргументах через цепочку вызовов (form_send -> http -> onreadystatechange -> success -> http -> onreadystatechange -> success)?
...
Рейтинг: 0 / 0
04.07.2019, 23:24
    #39834103
Alibek B
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Передать значение между вызовами
Почитал про области видимости closure и запутался.
В функции у меня объявлен ряд переменных:
Код: javascript
1.
2.
3.
4.
	var frm = document.forms.auth;
	var mode = frm.mode.value;
	var btn = frm.querySelector('button[type="submit"]');
	var tag = frm.querySelector('button[type="submit"] ~ .tag');


А также login, password, hash, auth и так далее.
Внутри события успешного выполнения auth-запроса в области closure консоль показывает, что имеются две переменные, btn и tag, указывающие на соответствующие элементы страницы.
А где остальные переменные? Почему именно эти попали в соответствующий scope?
...
Рейтинг: 0 / 0
04.07.2019, 23:37
    #39834112
Alibek B
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Передать значение между вызовами
Оказывается, нужно было просто в теле внутренней функции на эти переменные сослаться, тогда они и в консоли становятся видны.
То есть во внутренних функциях, вызываемых по событию, я просто ссылаюсь на переменные scope внешней функции, и все работает.
Чудеса.
...
Рейтинг: 0 / 0
05.07.2019, 13:22
    #39834355
OldMaster
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Передать значение между вызовами
Непонятно, зачем делать 2 функции.
Разве нельзя авторизовать пользователя 1 запросом?
...
Рейтинг: 0 / 0
05.07.2019, 14:52
    #39834386
Alibek B
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Передать значение между вызовами
Нет, там все довольно запутанно и одним запросом обойтись не удалось. Собственно авторизацию выполняет внешнее устройства и API для непосредственно авторизации не предусмотрено, поэтому нужно использовать http-сервлет.
...
Рейтинг: 0 / 0
Форумы / HTML, JavaScript, VBScript, CSS [игнор отключен] [закрыт для гостей] / Передать значение между вызовами / 5 сообщений из 5, страница 1 из 1
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


Просмотр
0 / 0
Close
Debug Console [Select Text]