찾기 - jquery 페이지 로드 후 실행




jQuery 로딩 스피너를 보여주는 법? (16)

Prototype 에서이 코드로 "loading ..."이미지를 보여줄 수 있습니다 :

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

function showLoad () {
    ...
}

jQuery 에서 다음과 같이 요소에 서버 페이지를로드 할 수 있습니다.

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

Prototype에서했던 것처럼 로딩 스피너를이 명령에 어떻게 첨부합니까?


자바 스크립트

$.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; }

AJAX 호출 바로 전에 애니메이션 이미지를 DOM에 삽입하고 인라인 함수를 사용하여 제거 할 수 있습니다.

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

이렇게하면 후속 요청에서 동일한 프레임에서 애니메이션이 시작됩니다 (문제가있는 경우). 이전 버전의 IE는 애니메이션에 어려움이 있을 수 있습니다.

행운을 빕니다!


jQuery UI 대화 상자에서 다음을 사용했습니다. (아마 다른 아약스 콜백과 함께 작동합니까?)

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

ajax 호출이 완료되면 콘텐츠가 대체 될 때까지 애니메이션 로딩 gif가 포함됩니다.


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 로더 생성기 인 웹 사이트입니다 : http://ajaxload.info/


그 쪽이 맞는 거 같아요. 이 방법은 너무 광범위합니다 ...

그러나 AJAX 호출이 페이지 자체에 아무런 영향을 미치지 않을 때 좋은 기본 설정입니다. (백그라운드 저장 예). (당신은 항상 "글로벌"전달하여 특정 아약스 호출 끄기 : false - 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);
};

나는 또한이 대답에 기여하고 싶다. 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>

그것은 그처럼 간단합니다 :)


나는 이것을한다:

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 호출을 사용하여 컨텐트를로드 할 동일한 태그에 로더 이미지를 할당 할 수 있습니다.

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

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

span 태그를 image 태그로 바꿀 수도 있습니다.



몇 가지 방법이 있습니다. 필자가 선호하는 방법은 요소 자체의 ajaxStart / Stop 이벤트에 함수를 연결하는 것입니다.

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

Ajax 호출을 수행 할 때마다 ajaxStart / Stop 함수가 실행됩니다.

업데이트 : jQuery 1.8부터, 설명서에는 .ajaxStart/Stopdocument 에만 첨부되어야한다고 나와 있습니다. 이렇게하면 위의 스 니펫이 다음과 같이 변환됩니다.

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

변형 : 메인 페이지의 왼쪽 상단에 id = "logo"아이콘이 있습니다. 아약스가 작동 할 때 스피너 gif가 상단에 겹쳐집니다 (투명도가 있음).

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

서버 요청을 할 때마다 로더를 사용할 계획이면 다음 패턴을 사용할 수 있습니다.

 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/



이것이 나를위한 최선의 방법입니다.

jQuery :

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

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

커피 :

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

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

문서 도구 : ajaxStart , ajaxStop


$.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'
    });  

$('#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>');

            }
        });




language-interoperability