Моделирование задержки Ajax - PullRequest
3 голосов
/ 17 июня 2011

У меня есть небольшой jjery-скрипт ajax, который возвращает мне XML.Пока он работает и общается с сервером, я отображаю анимацию загрузчика.

Проблема в том, что я не вижу анимацию.Либо я сделал что-то не так, либо соединение с сетью действительно быстрое.

Кто-нибудь знает, как я могу ввести задержку в свой код ajax, чтобы замедлить процесс и проверить функцию анимации?

Спасибо.

ps: код ajax ниже, просто incase

function fetchData($nodeid, $area){
    if( $nodeid != $currentRoomId ){
        popupBox($area);//$area, $roomInfo);
    }

        var $nid, $title, $classroom, $boardroom, $cabaret;
        $.ajax({

            url: "/room/" + $nodeid + "/rss.xml",
            dataType: "xml",
            success: function($xml){

                $returnXML  =   $xml;
                $($xml).find('node > *').each(
                    function(){

                        switch( $(this).attr('name') ){
                            case 'Nid':
                                $nid    =   $(this).text();
                            break;
                            case 'Title':
                                $title  =   $(this).text();
                            break;
                            case 'Classroom':
                                $classroom  =   $(this).text();
                            break;
                            case 'Boardroom':
                                $boardroom  =   $(this).text();
                            break;
                            case 'Cabaret':
                                $cabaret    =   $(this).text();
                            break;
                            case 'Theatre':
                                $theatre    =   $(this).text();
                            break;
                            case 'Notes':
                                $notes  =   $(this).text();
                            break;
                            default:
                            break;
                        }//close switch statement
                    }
                );
                $roomInfo   =   new Array();
                $roomInfo.push('Title', $title);
                $roomInfo.push('Classroom', $classroom);
                $roomInfo.push('Boardroom', $boardroom);
                $roomInfo.push('Cabaret', $cabaret);
                $roomInfo.push('Theatre', $theatre);
                $roomInfo.push('Notes', $notes);
                highlightRow($nid);
                popupBox($area, $roomInfo);
            },
            statusCode: {
                200: function(){
                    //alert('responding just fine!');
                }
            },
            error: function(){
                //alert('Ajax not responding!');
            },
            complete: function(){
                //alert('completed!');
            }
        });
    }

Ответы [ 3 ]

2 голосов
/ 17 июня 2011

Вы можете использовать setTimeout , чтобы ввести задержку.

1 голос
/ 28 октября 2012

Если у вас есть контроль над кодом вашего сервера, вы можете заставить сервер задерживать ответ AJAX, добавляя задержку в код вашего сервера, а не вызывая задержку в клиенте.

0 голосов
/ 17 июня 2011

Быстрое решение - переместить вызов ajax в блок if.В случае успеха / ошибки - скрыть анимацию.Это не будет имитировать задержку, но обеспечит отображение вашей анимации (даже если для мс).

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...