gpt4 book ai didi

javascript - 加载脚本的 AJAX 进度条

转载 作者:行者123 更新时间:2023-11-30 21:16:26 25 4
gpt4 key购买 nike

我在使用 AJAX 制作进度条时遇到了很大的问题。整个页面都在 AJAX 中,其中一个网页是 AJAX,它加载一个函数以从数据库中获取一些大行。

我试图在这个脚本中的 foreach 循环中使用 flush() 方法并通过写入/读取 $_SESSION 来制作进度条,但仍然没有。我真的尝试了一切我不知道该怎么做的事情。只需要这个来完成我的项目。有人可以帮我解决这个问题吗?

不管怎样,我想加载哪个脚本,这个进度条的模板如何在 GET 或 POST ajax 中使用它,对于任何 AJAX。

<script>
jQuery(document).ready(function($) {

$(document).on('click','#save',function () {
setTimeout(getProgress,1000);
$(this).text('Pobieram analizę...');
$.urlParam = function(name){
var results = new RegExp('[\?&]' + name + '=([^&#]*)').exec(window.location.href);
if (results==null){
return null;
}
else{
return decodeURI(results[1]) || 0;
}
}
var id = $.urlParam('id');
var idt = $.urlParam('idt');
$.ajax({
url: "views/getresults.php?id="+id+"&idt="+idt,
success: function(data) {
$("#loadresults").append(data);
}
});
setTimeout(getProgress,3000);
return false;
});
function getProgress(){

$.ajax({
url: 'views/listen.php',
success: function(data) {
if(data<=100 && data>=0){
console.log(data);
$('#loadresults').html('<div id="progress"><div class="progress-bar" role="progressbar" style="width:'+ (data / 100)*100 +'%">'+ data + '/' +100+'</div></div>');
setTimeout(getProgress,1000);
console.log('Repeat');
} else {
$('#loadresults').text('Pobieram dane');
console.log('End');
}
}
});
}
});
</script>

这是一个 getresults.php

    foreach($result as $resul) {
$count++;
session_start();
$_SESSION['progress'] = $count;
$_SESSION['total'] = 100;
session_write_close();
sleep(1);
}
unset($_SESSION['progress']);

和一个获取进度函数listen.php

<?php
session_start();
echo (!empty($_SESSION['progress']) ? $_SESSION['progress'] : '');

if (!empty($_SESSION['progress']) && $_SESSION['progress'] >= $_SESSION['total']) {
unset($_SESSION['progress']);
}

?>

最佳答案

写入和读取 session 不起作用,因为 PHP 的标准行为是在执行主代码时锁定 session 文件。

尝试创建一个文件并使用函数执行期间完成的百分比更新其内容。像这样的东西:

<?php
function slowFunction() {
$file = uniqid();
file_put_contents($file, 0);
// Long while that makes your stuff
// you have to know how many loops you will make to calculate the progress
$total = 100;
$done = 0;
while($done < $total) {
$done++;
// You may want not to write to the file every time to minimize changes of being writing the file
// at the same time your ajax page is fetching it, i'll let it to you...
$progress = $done / $total;
file_put_contents($file, $progress);
}
unlink($file); // Remove your progress file
}

?>

关于javascript - 加载脚本的 AJAX 进度条,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45646962/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com