web-dev-qa-db-ja.com

JQueryで負荷スピナーを表示するにはどうすればいいですか?

に プロトタイプ このコードで「読み込み中...」の画像を表示できます。

var myAjax = new Ajax.Request( url, {method: 'get', parameters: pars, 
onLoading: showLoad, onComplete: showResponse} );

function showLoad () {
    ...
}

に jQuery、私はこれで要素にサーバーページをロードすることができます:

$('#message').load('index.php?pg=ajaxFlashcard');

しかし、Prototypeで行ったように、どのようにしてローディングスピナーをこのコマンドにアタッチするのですか?

388
Edward Tanguay

いくつかの方法があります。私の好みの方法は、要素自体のajaxStart/Stopイベントに関数を添付することです。

$('#loadingDiv')
    .hide()  // Hide it initially
    .ajaxStart(function() {
        $(this).show();
    })
    .ajaxStop(function() {
        $(this).hide();
    })
;

AjaxStart/Stop関数は、Ajax呼び出しをするたびに起動されます。

更新 :jQuery 1.8以降、ドキュメントには.ajaxStart/Stopdocumentにのみ添付するように記載されています。これは上記のスニペットを次のように変換します。

var $loading = $('#loadingDiv').hide();
$(document)
  .ajaxStart(function () {
    $loading.show();
  })
  .ajaxStop(function () {
    $loading.hide();
  });
771
nickf

私が使用するjQueryの

jQuery.ajaxSetup({
  beforeSend: function() {
     $('#loader').show();
  },
  complete: function(){
     $('#loader').hide();
  },
  success: function() {}
});
202
kr00lix

JQueryの.ajax関数を使い、そのオプションbeforeSendを使って、ローダーdivのようなものを見せることができるいくつかの関数を定義することができ、成功時にはそのローダーdivを隠すことができます。

jQuery.ajax({
    type: "POST",
    url: 'YOU_URL_TO_WHICH_DATA_SEND',
    data:'YOUR_DATA_TO_SEND',
    beforeSend: function() {
        $("#loaderDiv").show();
    },
    success: function(data) {
        $("#loaderDiv").hide();
    }
});

あなたはどんな回転Gif画像も持つことができます。これはあなたの配色に応じて素晴らしいAJAXローダージェネレータであるウェブサイトです: http://ajaxload.info/

37
Seeker

アニメーション画像をAJAX呼び出しの直前にDOMに挿入し、それを削除するインライン関数を実行することができます。

$("#myDiv").html('<img src="images/spinner.gif" alt="Wait" />');
$('#message').load('index.php?pg=ajaxFlashcard', null, function() {
  $("#myDiv").html('');
});

これはあなたのアニメーションが後続の要求で同じフレームで開始することを確実にするでしょう(それが重要なら)。 IE mayの古いバージョンはアニメーションに問題があることに注意してください。

がんばろう!

22
Josh Stodola
$('#message').load('index.php?pg=ajaxFlashcard', null, showResponse);
showLoad();

function showResponse() {
    hideLoad();
    ...
}

http://docs.jquery.com/Ajax/load#urldatacallback

20
Brent

$.ajax()を使っているのなら、このようなものを使うことができます。

$.ajax({
        url: "destination url",
        success: sdialog,
        error: edialog,
        // shows the loader element before sending.
        beforeSend: function () { $("#imgSpinner1").show(); },
        // hides the loader after completion of request, whether successfull or failor.             
        complete: function () { $("#imgSpinner1").hide(); },             
        type: 'POST', dataType: 'json'
    });  
15
Amin Saqi

ローディングプラグインを使用します。 http://plugins.jquery.com/project/loading

$.loading.onAjax({img:'loading.gif'});
10
Nathan Bubna

Variant:メインページの左上にid = "logo"のアイコンがあります。 ajaxが動作しているときは、スピナーgifが上に(透明に)重ねられます。

jQuery.ajaxSetup({
  beforeSend: function() {
     $('#logo').css('background', 'url(images/ajax-loader.gif) no-repeat')
  },
  complete: function(){
     $('#logo').css('background', 'none')
  },
  success: function() {}
});
8
Paul

私もこの答えに貢献したいと思います。私はjQueryで似たようなものを探していましたが、これが最終的に使用したものです。

ローディングスピナーは http://ajaxload.info/ から入手しました。私の解決策は http://christierney.com/2011/03/23/global-ajax-loading-spinners/ にあるこの単純な答えに基づいています。

基本的にあなたのHTMLマークアップとCSSはこのように見えるでしょう:

<style>
     #ajaxSpinnerImage {
          display: none;
     }
</style>

<div id="ajaxSpinnerContainer">
     <img src="~/Content/ajax-loader.gif" id="ajaxSpinnerImage" title="working..." />
</div>

そして、あなたはjQueryのためのコードはこのようなものになるでしょう:

<script>
     $(document).ready(function () {
          $(document)
          .ajaxStart(function () {
               $("#ajaxSpinnerImage").show();
          })
          .ajaxStop(function () {
               $("#ajaxSpinnerImage").hide();
          });

          var owmAPI = "http://api.openweathermap.org/data/2.5/weather?q=London,uk&APPID=YourAppID";
          $.getJSON(owmAPI)
          .done(function (data) {
               alert(data.coord.lon);
          })
          .fail(function () {
               alert('error');
          });
     });
</script>

それはそれと同じくらい簡単です:)

7
Brendan Vogt

元の返信 に2つの変更を加えました。

  1. JQuery 1.8以降、ajaxStartとajaxStopはdocumentにのみ添付されるべきです。これにより、一部のajaxリクエストのみをフィルタリングすることが難しくなります。そう….
  2. ajaxSend および ajaxComplete に切り替えると、スピナーを表示する前に現在のajaxリクエストを調べることができます。

これは、これらの変更後のコードです。

$(document)
    .hide()  // hide it initially
    .ajaxSend(function(event, jqxhr, settings) {
        if (settings.url !== "ajax/request.php") return;
        $(".spinner").show();
    })
    .ajaxComplete(function(event, jqxhr, settings) {
        if (settings.url !== "ajax/request.php") return;
        $(".spinner").hide();
    })
7
Emil Stenström

Ajax呼び出しを使用して、後でコンテンツをロードするのと同じタグに単純にローダーイメージを割り当てることができます。

$("#message").html('<span>Loading...</span>');

$('#message').load('index.php?pg=ajaxFlashcard');

スパンタグをイメージタグに置き換えることもできます。

7
Umesh kumar

Ajaxイベントにグローバルデフォルトを設定するだけでなく、特定の要素に動作を設定することもできます。クラスを変更するだけで十分でしょうか。

$('#myForm').ajaxSend( function() {
    $(this).addClass('loading');
});
$('#myForm').ajaxComplete( function(){
    $(this).removeClass('loading');
});

スピナーを使用して#myFormを非表示にするCSSの例:

.loading {
    display: block;
    background: url(spinner.gif) no-repeat center middle;
    width: 124px;
    height: 124px;
    margin: 0 auto;
}
/* Hide all the children of the 'loading' element */
.loading * {
    display: none;  
}
6
LeeGee
$('#loading-image').html('<img src="/images/ajax-loader.gif"> Sending...');

        $.ajax({
            url:  uri,
            cache: false,
            success: function(){
                $('#loading-image').html('');           
            },

           error:   function(jqXHR, textStatus, errorThrown) {
            var text =  "Error has occured when submitting the job: "+jqXHR.status+ " Contact IT dept";
           $('#loading-image').html('<span style="color:red">'+text +'  </span>');

            }
        });
4

スピナーには非同期呼び出しを使用する必要があることに注意してください(少なくともこれがajax呼び出しの後まで表示されず、呼び出しが終了してスピナーを削除したためにすぐに消えてしまう原因です)。

$.ajax({
        url: requestUrl,
        data: data,
        dataType: 'JSON',
        processData: false,
        type: requestMethod,
        async: true,                         <<<<<<------ set async to true
        accepts: 'application/json',
        contentType: 'application/json',
        success: function (restResponse) {
            // something here
        },
        error: function (restResponse) {
            // something here                
        }
    });
3
Shane Rowatt

私はjQuery UI Dialogで以下を使いました。 (多分それは他のajaxコールバックと一緒に動作しますか?)

$('<div><img src="/i/loading.gif" id="loading" /></div>').load('/ajax.html').dialog({
    height: 300,
    width: 600,
    title: 'Wait for it...'
});

Ajax呼び出しが完了したときにコンテンツが置き換えられるまで、これにはアニメーションロードgifが含まれています。

2
Quinn Comendant

JavaScript

$.listen('click', '#captcha', function() {
    $('#captcha-block').html('<div id="loading" style="width: 70px; height: 40px; display: inline-block;" />');
    $.get("/captcha/new", null, function(data) {
        $('#captcha-block').html(data);
    }); 
    return false;
});

CSS

#loading { background: url(/image/loading.gif) no-repeat center; }
2
Jerry

これは私にとって最良の方法です。

jQuery

$(document).ajaxStart(function() {
  $(".loading").show();
});

$(document).ajaxStop(function() {
  $(".loading").hide();
});

コーヒー

  $(document).ajaxStart ->
    $(".loading").show()

  $(document).ajaxStop ->
    $(".loading").hide()

ドキュメント: ajaxStartajaxStop

2
Fred K

これはその特定の目的のための非常にシンプルでスマートなプラグインです: https://github.com/hekigan/is-loading

2
andcl

サーバー要求を行うたびにローダーを使用する予定の場合は、次のパターンを使用できます。

 jTarget.ajaxloader(); // (re)start the loader
 $.post('/libs/jajaxloader/demo/service/service.php', function (content) {
     jTarget.append(content); // or do something with the content
 })
 .always(function () {
     jTarget.ajaxloader("stop");
 });

このコードは特にjajaxloaderプラグイン(私が作成したばかり)を使用しています

https://github.com/lingtalfi/JAjaxLoader/ /

1
ling

あなたがあなた自身のコードを書きたくないのであれば、まさにそれをするたくさんのプラグインもあります:

1
keithhackbarth

私はこれをします:

var preloaderdiv = '<div class="thumbs_preloader">Loading...</div>';
           $('#detail_thumbnails').html(preloaderdiv);
             $.ajax({
                        async:true,
                        url:'./Ajaxification/getRandomUser?top='+ $(sender).css('top') +'&lef='+ $(sender).css('left'),
                        success:function(data){
                            $('#detail_thumbnails').html(data);
                        }
             });
1
user968652

私はあなたが正しいと思います。この方法はグローバルすぎます...

ただし、AJAX呼び出しがページ自体に影響を及ぼさない場合は、これが良いデフォルトです。 (背景保存など) ( "global":falseを渡すことで、特定のajax呼び出しに対していつでもオフにすることができます。 jquery のドキュメントを参照してください。

AJAX呼び出しがページの一部を更新することを目的としている場合、私は "読み込み中"の画像が更新されたセクションに固有であることが好きです。どの部分が更新されるのかを確認したいのですが。

あなたが単純に次のようなものを書くことができればそれがどれほどクールになるか想像してみてください。

$("#component_to_refresh").ajax( { ... } ); 

そしてこれは、このセクションの「ロード」を示しています。下記は私が書いた関数で、 "読み込み"表示も処理しますが、それはあなたがajaxでリフレッシュしている分野に特有のものです。

まず、使い方を説明しましょう。

<!-- assume you have this HTML and you would like to refresh 
      it / load the content with ajax -->

<span id="email" name="name" class="ajax-loading">
</span>

<!-- then you have the following javascript --> 

$(document).ready(function(){
     $("#email").ajax({'url':"/my/url", load:true, global:false});
 })

そしてこれが機能です - あなたが望むように強化できる基本的なスタートです。とても柔軟です。

jQuery.fn.ajax = function(options)
{
    var $this = $(this);
    debugger;
    function invokeFunc(func, arguments)
    {
        if ( typeof(func) == "function")
        {
            func( arguments ) ;
        }
    }

    function _think( obj, think )
    {
        if ( think )
        {
            obj.html('<div class="loading" style="background: url(/public/images/loading_1.gif) no-repeat; display:inline-block; width:70px; height:30px; padding-left:25px;"> Loading ... </div>');
        }
        else
        {
            obj.find(".loading").hide();
        }
    }

    function makeMeThink( think )
    {
        if ( $this.is(".ajax-loading") )
        {
            _think($this,think);
        }
        else
        {
            _think($this, think);
        }
    }

    options = $.extend({}, options); // make options not null - ridiculous, but still.
    // read more about ajax events
    var newoptions = $.extend({
        beforeSend: function()
        {
            invokeFunc(options.beforeSend, null);
            makeMeThink(true);
        },

        complete: function()
        {
            invokeFunc(options.complete);
            makeMeThink(false);
        },
        success:function(result)
        {
            invokeFunc(options.success);
            if ( options.load )
            {
                $this.html(result);
            }
        }

    }, options);

    $.ajax(newoptions);
};
1
guy mograbi

私のajaxコードはこのようになっています。事実、async:false lineとコメントアウトしたところでスピナーが現れています。

$.ajax({
        url: "@Url.Action("MyJsonAction", "Home")",
        type: "POST",
        dataType: "json",
        data: {parameter:variable},
        //async: false, 

        error: function () {
        },

        success: function (data) {
          if (Object.keys(data).length > 0) {
          //use data 
          }
          $('#ajaxspinner').hide();
        }
      });

私はajaxコードの前の関数内でスピナーを見せています。

$("#MyDropDownID").change(function () {
        $('#ajaxspinner').show();

HTMLでは、私はフォント素晴らしいクラスを使用しました:

<i id="ajaxspinner" class="fas fa-spinner fa-spin fa-3x fa-fw" style="display:none"></i>

誰かに役立つことを願っています。

1
Jaggan_j

あなたはいつでも Block UI jQuery plugin を使うことができます - そしてそれはあなたのためにすべてをします、そしてそれはajaxがロードされている間それはどんな入力のページもブロックします。プラグインが動作していないように思われる場合、あなたはそれを使用する正しい方法について読むことができます この答えで。 見てみな。

0
SamyCode