>  기사  >  백엔드 개발  >  AJAX 데이터 로딩을 위한 진행률 표시줄을 구현하는 방법은 무엇입니까?

AJAX 데이터 로딩을 위한 진행률 표시줄을 구현하는 방법은 무엇입니까?

DDD
DDD원래의
2024-10-24 06:04:30464검색

How to Implement a Progress Bar for AJAX Data Loading?

AJAX 데이터 로딩을 위한 진행률 표시줄 통합

사용자가 웹 애플리케이션과 상호작용할 때 진행 중인 프로세스를 나타내는 시각적 단서를 제공하는 것이 중요합니다. 특히 시간이 많이 걸리는 작업 중에는 더욱 그렇습니다. 이 문서에서는 AJAX를 통해 데이터를 로드하는 동안 진행률 표시줄을 표시하는 방법을 제안합니다.

다음 시나리오를 고려해 보세요. 드롭다운 상자에 사용자에게 값을 선택하라는 메시지가 표시됩니다. 선택하면 AJAX 요청이 데이터베이스에서 데이터를 검색하고 표시합니다. 다만, 응답에는 다소 시간이 걸릴 수 있습니다. 사용자 경험을 향상시키기 위해 시각적 진행률 표시기를 통합하려고 합니다.

제공된 AJAX 코드에는 다음이 포함됩니다.

<code class="html">$.ajax({
    type:"post",
    url:"clientnetworkpricelist/yourfile.php",
    data:"title="+clientid,
    success:function(data){
     $("#result").html(data);
    }
});</code>

진행률 표시줄을 추가하려면 XMLHttpRequest의 진행률 이벤트 리스너를 활용하세요. 물체. jQuery를 사용하여 이를 구현하는 방법은 다음과 같습니다.

<code class="html">$.ajax({
    xhr: function() {
        var xhr = new window.XMLHttpRequest();

        // Upload progress
        xhr.upload.addEventListener("progress", function(evt) { 
            if (evt.lengthComputable) {
                var percentComplete = evt.loaded / evt.total; 
                //Handle upload progress here
            } 
        }, false); 
       
       // Download progress
       xhr.addEventListener("progress", function(evt){ 
           if (evt.lengthComputable) {
               var percentComplete = evt.loaded / evt.total; 
               //Handle download progress here
           }
       }, false); 
       
       return xhr;
    },
    type: 'POST',
    url: &quot;/&quot;,
    data: {},
    success: function(data){ 
        // Handle successful response
    }
});</code>

이 코드는 진행 이벤트 리스너를 xhr 개체에 연결하여 업로드 및 다운로드 진행 상황을 모두 추적할 수 있도록 합니다. PercentComplete 변수는 진행률을 계산하므로 적절한 진행률 표시줄 구현을 사용하여 사용자에게 이를 표시할 수 있습니다.

위 내용은 AJAX 데이터 로딩을 위한 진행률 표시줄을 구현하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.