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.

  • 11 Опрос

    You do not have permission to vote in this poll, or see the poll results. Please sign in or register to vote in this poll.
  • Обсуждения

    • суть вкладок такая же может быть, код скрипта нужно править, сейчас все вкладки у вас будут подгружать один и тот же iframe   <span class="address-link" data-target-id="target-div" data-target="http://site.ru/page1/">вкладка1</span> <span class="address-link" data-target-id="target-div" data-target="http://site.ru/page2/">вкладка2</span> <div id="target-div"></div>   $('.address-link').click(function(){    var targetId = $(this).data('target-id');    var target = $(this).data('target');    $('#' + targetId).html('<iframe src="'+target +'"></iframe>');  }); Не понятно что за скрипты вы планируете грузить, по сути ни чего не мешает грузить скрипты, и даже iframe через скрипты
    • Обновить пример и получить результат:
    • Помогите если кто знает. Задача такая - на сторонней cms нужно найти кусок кода из описания и добавить его в поле meta-description. Описание товаров забивается макросом %contents% но этот макрос добавляет все описание, характеристики, цену и т.д нужный кусок кода с описанием выгдлядит так: <div id="item-description" class="item-passage"> <div class="item-description" itemprop="description"> <p class="b-user-content" data-extend="FlexibleTable" itemprop="description"> FM-трансмиттер предназначен для воспроизведения музыкальных файлов с карт памяти microSD и USB накопителей и трансляции звука на приёмник в автомобиле. Питается устройство от гнезда прикуривателя 12В. В комплекте поставляется дистанционный ИК-пульт для управления трансмиттером. AFM-L-01 ... </p> </div> </div> можно ли как то с помощью CSS возможно зафиксировать его в поле description??
    • Здравствуйте! Простите, если не сюда пишу. Что-то намудрил в стилях и при попытке изменения цвета вертикальной линии, цвет не меняется. Подскажите, пожалуйста, как корректно изменить цвет вертикальной линии. Код и результат можно посмотреть здесь https://jsfiddle.net/sn2uo9k4/   Буду благодарен советам!
    • Как это вместе использовать?   
×
×
  • 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. See more about our Guidelines and Privacy Policy