Javascript-форум (https://javascript.ru/forum/)
-   Javascript под браузер (https://javascript.ru/forum/css-html/)
-   -   Скрипт некорректно работает. Как можно исправить? (https://javascript.ru/forum/css-html/72199-skript-nekorrektno-rabotaet-kak-mozhno-ispravit.html)

antonhauff 15.01.2018 12:59

Скрипт некорректно работает. Как можно исправить?
 
Есть юзерскрипт (некоторые переменные и шелуху, не очень информативную, я выбросил):
(function (window, undefined) {  // [2] нормализуем window
var w;
if (typeof unsafeWindow != undefined) {
    w = unsafeWindow;
} else {
    w = window;
}
if (w.self != w.top) {
    return;
}

function start() {
    var read = getread();
    checkResult(read);
}

function checkResult(last_read) {
    setTimeout(function() {
        if (last_read < getread()) {
        //1-ый блок
        } else if (last_read > getread()) {
        //2-ый блок
        } else {
        //3-ый блок
        checkResult(last_read);
        }
    }, 500);
}

function getread() {
}

function minimum_rate() {
}

function callnetwork() {
}
})(window);


Данный скрипт парсит онлайн чат некоторого сайта. Иногда на функции checkResult скрипт не может получить ответ от сайта. В таком случае выполняет третье условие (третий блок) и перезапускает функцию checkResult() снова. И так может быть несколько раз. Но порой, после неоднократного повторения третьего блока функции checkResult() в консоле можно увидеть ошибку "Failed to load resource: the server responded with a status of 429 ()" либо какой-нибудь другую (например иногда это может быть 500(), либо 502()). В таком случае, скрипт "зависает" на бесконечном выполнении третьего блока функции checkResult().

Подскажите пожалуйста, как можно поправить логику скрипта, чтобы не возникала такая ошибка?

Dilettante_Pro 15.01.2018 13:17

antonhauff,
Не знаю, что у вас в функции getread(), но я бы вынес обращение к ней повыше - чтобы оно шло один раз за цикл анализа результата

function checkResult(last_read) {
    setTimeout(function() {
        var readresult = getread();
        if (last_read < readresult) {
        //1-ый блок
        } else if (last_read > readresult) {
        //2-ый блок
        } else {
        //3-ый блок
        checkResult(last_read);
        }
    }, 500);
}

При двух отдельных вызовах могут быть разные результаты, и логика проверки нарушается

Aetae 15.01.2018 13:18

Слишком много выкинуто.
Откуда берётся last_read? Что выдаёт getread()?
Очевидно, что last_read навсегда остаётся равным getread(), а почему это происходит, без представления откуда что берётся, не скажут и телепаты.

Dilettante_Pro 15.01.2018 13:25

Aetae,
Цитата:

Сообщение от Aetae
Очевидно, что last_read навсегда остаётся равным getread()

Откуда это очевидно? Это присвоение указано только в функции start.
Когда вызывается функция start?
Что возвращает функция getread() при последующих вызовах?

Цитата:

Сообщение от antonhauff
некоторые переменные и шелуху, не очень информативную, я выбросил

И ребенка вместе с водой....

Aetae 15.01.2018 13:30

Цитата:

Сообщение от Dilettante_Pro (Сообщение 475237)
Откуда это очевидно?

Из того что тетий блок выполняется постоянно, а выше проверятся условие как > так и <. *пожал плечами*
Конечно и last_read и возврат getread() как-то могут меняться(сомневаюсь), но так или иначе last_read остаётся равным getread(). :)

Dilettante_Pro 15.01.2018 13:43

Aetae,
Цитата:

Сообщение от Aetae
возврат getread() как-то могут меняться(сомневаюсь), но так или иначе last_read остаётся равным getread()

Это только гадание на кофейной гуще, но, предположительно:
- last_read задаётся равным getread() в функции start
- функция checkResult крутится и ждет, когда изменится getread()

Конечно, если в функции start вызов getread() сразу даст окончательный результат ... то ждать можно до бесконечности

antonhauff 15.01.2018 19:46

Вернул "шелуху" которая взаимодействует с сайтом:)
(function (window, undefined) {  // [2] нормализуем window
var w;
if (typeof unsafeWindow != undefined) {
    w = unsafeWindow;
} else {
    w = window;
}
if (w.self != w.top) {
    return;
}

function start() {
    var read = getread();
    $('.read_htable input[name=bet]').val(parseFloat(current_bet).toFixed(8));
        read_on = callnetwork();
        var readBtn = $('.read_htable .clRead')[read_on];
        readBtn.click();
        checkResult(read);
}

function checkResult(last_read) {
    setTimeout(function() {
        if (last_read < getread()) {
        //1-ый блок
        } else if (last_read > getread()) {
        //2-ый блок
        } else {
        //3-ый блок
        checkResult(last_read);
        }
    }, 500);
}

function getread() {
        var write_text = $('.read_select .chosen-single span').text();
        var regex = /[+-]?\d+(\.\d+)?/g;
        var floats = read_text.match(regex).map(function(v) {
            return parseFloat(v).toFixed(8);
        });

        return floats[0];
}

function minimum_rate() {
}

function callnetwork() {
}
})(window);


Скрипт в процессе работы нажимает в окне чата на две кнопки (в зависимости от алгоритма) и далее по скрипту.
Иногда, сайт "подвисает" и изменение в окне чата происходит с некоторой задержкой, после чего собственно и происходит застревание на третьем блоке функции checkResult.

Я так понимаю, тогда надо как-то отследить есть ли изменения после нажатия кнопки? Как это можно сделать?

antonhauff 15.01.2018 19:52

Немного не так. Если после нажатия кнопки (код я добавил, он находится в функции start()) в чате произошли изменения, то last_read не равен getread(). Но порой, кнопка нажимается долго (сайт подлагивает) и в таком случае ,дальнейший код выполняется быстрее чем появляюься изменения в чате и тогда last_read равен getread() и мы попадаем в третий блок.

Dilettante_Pro 16.01.2018 11:56

antonhauff,
Все-таки настоятельно рекомендую изменить функцию checkResult в соответствии с Пост№2

antonhauff 16.01.2018 12:13

Цитата:

Сообщение от Dilettante_Pro (Сообщение 475305)
antonhauff,
Все-таки настоятельно рекомендую изменить функцию checkResult в соответствии с Пост№2

Да, спасибо, изменил.
Еще поменял обработчик click на onclik, чтобы дальнейший код выполнялся только после того, как кнопка нбудет нажата и будет изменение в чате.


Часовой пояс GMT +3, время: 12:34.