Jump to content
  • 0

Без вызова Alert("текст") не применяется значение.


Question

Сразу скажу за основу брал чужой код. Есть основная страничка страничка. На ней меню, по нажатию на ссылки в котором открываются другие странички.

Так вот по открытию одной из них считываются имена файлов, расположенных на устройстве. Они и считываются.

   function GetList(submit) {
	    var server = "/list?dir=/";
        send_request(submit, server);
        alert("блаблабла");
        alert('2' + submit.value);
    }
  
function send_request(submit,server){
    var request = new XMLHttpRequest();
    request.open("GET", server, true);
    request.send();
    save_status(submit,request);
    //alert('1' + submit.value);
   }
   
   function save_status(submit,request){
    var new_submit;
    var old_submit = submit.value;
    request.onreadystatechange = function() {
     if (request.readyState != 4) return;
     submit.value = request.responseText;
     new_submit = request.responseText;
     setTimeout(function(){
      submit.value=old_submit;
      submit_disabled(false);
     }, 1000);
    }
    submit.value = 'Подождите...';
    submit.value = new_submit;
    submit_disabled(true);
}
   
   function submit_disabled(request){
    var inputs = document.getElementsByTagName("input");
    for (var i = 0; i < inputs.length; i++) {
     if (inputs[i].type === 'submit') {inputs[i].disabled = request;}
    }
   }

Первая функция отправляет запрос на устройство. Устройство считывает список файлов и возвращает в виде массива типа

[{"type":"dir","name":"first"},{"type":"file","name":"second"}]

Но вот если в первой функции убрать всплывающее окошко по алерту с блаблабла, то alert('2' + submit.value); выдает "2undefined". Можно конечно вместо блаблабла написать вумную фразу, типа "Данные собираются". Но как-то это неправильно. Подскажите, что сделать, чтобы без этого окна применялось значение. Я всю голову сломал. Тут что-то с последовательностью действий. Например вот если я вставлю в какую нибудь функцию send_request тоже какой-нибудь алерт, то алерт из первой функции выскакивает первый! В других языках программирования тот алерт, что в вызываемой йункции первым бы отработал. А тут такая фигня. Не могу понять этого!

Link to post
Share on other sites

7 answers to this question

Recommended Posts

  • 0

Async + await. 

Нужно ждать, когда request обработается, а только потом что-то делать с value. Какая-то микросекунда буксует.

Также state для submit не хорошие.

Edited by Full-R
Link to post
Share on other sites
  • 0
6 часов назад, Delphin911 сказал:

Это я понял. А что делать то?

Не хочу ваш устаревший XHR переделывать. Вот тут посмотрите: Не срабатывает цикл for - ECMAScript - Учим делать сайты. HTML форум. (htmlforum.io).

Alert не делайте. Есть console.log и promt. 

Link to post
Share on other sites
  • 0

console.log не помогает. Попробовал сейчас после вашего совета. Оно даже в консоль не выводится.

function SaveConfig(submit) {
	var server = "/saveSettings?ssid=" + val('ssid') + "&password=" + encodeURIComponent(val('password')) + "&passwordAP=" + encodeURIComponent(val('passwordAP')) + "&ssidAP=" + val('ssidAP') + "&SSDP=" + val('SSDP') + "&IPAP=" + val('IPAP');
    send_request(submit,server);
    console.log("Изменения сохранены.");
	location.reload();
}

Вот у меня вместо console.log был alert и все срабатывало. А тут видно перезагрузка срабатывает раньше и не дает сохраниться и в лог консоли отправить.

Link to post
Share on other sites
  • 0

К стати если на компе во всех броузерах работает, то на смартфоне почему-то эта динамически строящаяся таблица не отрисовывается! В чем может быть дело?

Продолжаю бороться с задержкой при выводе результата и начинаю думать, что дело не в ней. Вот что написал почитав просторы инета:

unction GetList(submit) {
    	        var fl;
                var server = "/list?dir=/";
                send_request(submit, server);
                //alert("Считываем список файлов...");
                //fl = submit.value;
                //if (fl.length) {return fl;}
                //else {console.log("wait...");setTimeout(GetList, 500);}
                sleep(5000);
                return submit.value;
            }

            function sleep(milliseconds) {
                const date = Date.now();
                let currentDate = null;
                do {
                    currentDate = Date.now();
                } while (currentDate - date < milliseconds);
            }

Да, реально проходит 5 секунд ожидания, но на выходе пусто. Вот там еще закомментированные строки, тоже не работают. Толко alert спасает ситуацию.

Ну и к стати мне кажется, что на смартфоне и alert не помогает. Пустая страница.

Link to post
Share on other sites
  • 0

alert('2' + submit.value) нужно было делать внутри request.onreadystatechange, потому что именно там приходит значение с сервера и задаётся value у submit. И через сколько времени это произойдёт, не всегда известно, может и через минуту, если интернет медленный, поэтому таймаутами универсально не побороть.

Link to post
Share on other sites

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.
Note: Your post will require moderator approval before it will be visible.

Guest
Answer this question...

×   Pasted as rich text.   Paste as plain text instead

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

  • Комментарии

    • alert('2' + submit.value) нужно было делать внутри request.onreadystatechange, потому что именно там приходит значение с сервера и задаётся value у submit. И через сколько времени это произойдёт, не всегда известно, может и через минуту, если интернет медленный, поэтому таймаутами универсально не побороть.
    • Я не уверен, что у формы есть событие input, но если даже было бы, то переменные result, num1 и num2 не определены. Они были бы созданы автоматически, если бы это были id, но у тебя-то name. И я не в курсе, сейчас можно писать js-код в атрибутах без javascript: спереди? И есть ли у тега <output> свойство value? Может быть, у него textContent? Подключи Vue, там будет работать так, как ты хочешь, только придётся несколько дополнительных действий сделать, привязывая переменные к инпутам и создавая computed-свойство.
    • В телеграме картинка есть, вконтакт тоже показывает, даже в аське есть. Видимо, ты как-то не так проверяешь.
    • Понял, спасибо большое. Я просто думал, что если выбран класс, то и применяяется только к конкретному классу, а оказывается не правильно думал. Еще раз спасибо
    • Добрый день! Есть такая страница http://tehne.com/grant/right-bank-of-kazanka-river-competition-2021-ru Хочу сделать чтобы в мессенджерах когда отправляют ссылку вместе с заголовком показывалась определенная картинка. Я добавил эту картинку в мета тэги og и link rel="image_src"  и она все равно не появляется когда делюсь в мессенджерах Почему так?  
×
×
  • Create New...

Important Information

We have placed cookies on your device to help make this website better. You can adjust your cookie settings, otherwise we'll assume you're okay to continue.