jQueryでローディングスピナーを表示するにはどうすればよいですか?
-
09-06-2019 - |
質問
で プロトタイプ 次のコードで「読み込み中...」画像を表示できます。
var myAjax = new Ajax.Request( url, {method: 'get', parameters: pars,
onLoading: showLoad, onComplete: showResponse} );
function showLoad () {
...
}
で jQuery, これを使用してサーバーページを要素にロードできます。
$('#message').load('index.php?pg=ajaxFlashcard');
しかし、プロトタイプで行ったように、このコマンドに読み込みスピナーをアタッチするにはどうすればよいでしょうか?
解決
いくつかの方法があります。私の推奨する方法は、要素自体の ajaxStart/Stop イベントに関数をアタッチすることです。
$('#loadingDiv')
.hide() // Hide it initially
.ajaxStart(function() {
$(this).show();
})
.ajaxStop(function() {
$(this).hide();
})
;
ajaxStart/Stop 関数は、Ajax 呼び出しを実行するたびに起動されます。
アップデート:jQuery 1.8 の時点で、ドキュメントには次のように記載されています。 .ajaxStart/Stop
にのみ添付する必要があります document
. 。これにより、上記のスニペットは次のように変換されます。
var $loading = $('#loadingDiv').hide();
$(document)
.ajaxStart(function () {
$loading.show();
})
.ajaxStop(function () {
$loading.hide();
});
他のヒント
私が使用するjQueryの場合
jQuery.ajaxSetup({
beforeSend: function() {
$('#loader').show();
},
complete: function(){
$('#loader').hide();
},
success: function() {}
});
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();
}
});
任意の Spinning GIF 画像を使用できます。以下は、配色に応じた優れた AJAX ローダー ジェネレーターである Web サイトです。 http://ajaxload.info/
AJAX 呼び出しの直前にアニメーション イメージを DOM に挿入し、インライン関数を実行してそれを削除できます。
$("#myDiv").html('<img src="images/spinner.gif" alt="Wait" />');
$('#message').load('index.php?pg=ajaxFlashcard', null, function() {
$("#myDiv").html('');
});
これにより、後続のリクエストでもアニメーションが同じフレームで開始されるようになります (それが重要な場合)。IEのバージョンが古いので注意してください。 かもしれない アニメーションに問題があります。
幸運を!
$('#message').load('index.php?pg=ajaxFlashcard', null, showResponse);
showLoad();
function showResponse() {
hideLoad();
...
}
使用している場合 $.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'
});
読み込みプラグインを使用します。 http://plugins.jquery.com/project/loading
$.loading.onAjax({img:'loading.gif'});
変異体:メインページの左上に 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() {}
});
結局、2つの変更を加えました 元の返信.
- jQuery 1.8 の時点では、ajaxStart と ajaxStop は以下にのみ接続する必要があります。
document
. 。これにより、一部の ajax リクエストのみをフィルタリングすることが難しくなります。すっ... - に切り替える ajax送信 そして 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();
})
私もこの回答に貢献したいと思います。私は 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>
それはとても簡単です:)
ローダー イメージを同じタグに割り当てるだけで、後で Ajax 呼び出しを使用してコンテンツをロードすることができます。
$("#message").html('<span>Loading...</span>');
$('#message').load('index.php?pg=ajaxFlashcard');
また、span タグをイメージ タグに置き換えることもできます。
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;
}
スピナーが機能するには非同期呼び出しを使用する必要があることに注意してください (少なくともこれが、私の場合は 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
}
});
$('#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>');
}
});
jQuery UIダイアログで以下を使用しました。(おそらく他の ajax コールバックでも動作するのでしょうか?)
$('<div><img src="/i/loading.gif" id="loading" /></div>').load('/ajax.html').dialog({
height: 300,
width: 600,
title: 'Wait for it...'
});
には、ajax 呼び出しが完了してコンテンツが置き換えられるまで、アニメーションの読み込み GIF が含まれています。
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; }
これは、その特定の目的のための非常にシンプルでスマートなプラグインです。https://github.com/hekigan/is-loading
私はこれをします:
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);
}
});
あなたが正しいと思います。この方法はグローバルすぎる...
ただし、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);
};
独自のコードを書きたくない場合は、それを行うプラグインがたくさんあります。
サーバーリクエストを行うたびにローダーを使用する予定がある場合は、次のパターンを使用できます。
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 プラグイン (先ほど作成したもの) を使用しています。
私の ajax コードは次のようになります。実際には、async をコメントアウトしただけです。偽のラインとスピナーが表示されます。
$.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>
誰かの役に立てば幸いです。
いつでもご利用いただけます ブロック UI jQuery プラグイン これはすべてを自動的に実行し、ajax のロード中に入力のページをブロックすることさえあります。プラグインが機能していないと思われる場合は、プラグインの正しい使用方法についてお読みください。 この回答では。 それをチェックしてください。