导航:首页 > 编程语言 > php实现进度条

php实现进度条

发布时间:2022-09-01 05:09:16

A. ajax+php实现进度显示是怎么实现的

php+ajax实现进度条
代码如下:

<?php

//set_time_limit(0); //注意,如果是安全模式,请不要打开,如果不是安全模式,这个选项可以打开
for ($i = 0; $i < 500; $i++) {
$users[] = 'Tom_' . $i;
for
$width = 500; //显示的进度条长度,单位 px
$total = count($users); //总共需要操作的记录数
$pix = $width / $total; //每条记录的操作所占的进度条单位长度
$progress = 0; //当前进度条长度
?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN""http://www.w3.org/TR/xhtml1/DTD/transitional.dtd">
<html>
<head>
<title>动态显示服务器运行程序的进度条</title>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<style>
body, div input { font-family: Tahoma; font-size: 9pt }
</style>
<script language="JavaScript">
<!--
function updateProgress(sMsg, iWidth)
{
document.getElementById("status").innerHTML = sMsg;
document.getElementById("progress").style.width = iWidth + "px";
document.getElementById("percent").innerHTML = parseInt(iWidth / <?php echo$width; ?> * 100) + "%";
}
//-->
</script>
</head>

<body>
<div style="margin: 4px; padding: 8px; border: 1px solid gray; background: #EAEAEA; width: <?php echo $width+8; ?>px">
<div><font color="gray">如下进度条的动态效果由服务器端 PHP 程序结合客户端 JavaScript 程序生成。</font></div>
<div style="padding: 0; background-color: white; border: 1px solid navy; width: <?php echo $width; ?>px">
<div id="progress" style="padding: 0; background-color: #FFCC66; border: 0; width: 0px; text-align: center; height: 16px"></div>
</div>
<div id="status"> </div>
<div id="percent" style="position: relative; top: -30px; text-align: center; font-weight: bold; font-size: 8pt">0%</div>
</div>
<?php
flush(); //将输出发送给客户端浏览器
foreach ($users as $user) {
// 在此处使用空循环模拟较为耗时的操作,实际应用中需将其替换;
// 如果你的操作不耗时,我想你就没必要使用这个脚本了 :)
// 请在这里处理你的业务
for ($i = 0; $i < 1000000; $i++) {
;;
}
?>
<script language="JavaScript">
updateProgress("正在操作用户“<?php echo $user; ?>” ....", <?php echo min($width,intval($progress)); ?>);
</script>
<?php
flush(); //将输出发送给客户端浏览器,使其可以立即执行服务器端输出的 JavaScript 程序。
$progress += $pix;
} //end foreach
// 最后将进度条设置成最大值 $width,同时显示操作完成
?>
<script language="JavaScript">
updateProgress("操作完成!", <?php echo $width; ?>);
</script>
<?php
flush();
?>
</body>
</html>

B. php 如何做进度条

配合前端来做 先做一个宽度100%的灰色矩形 上面覆盖一个有颜色的矩形 默认宽度0
后端把数据渲染到前端 数据要在后端处理成百分比 也就是 值/总数*100 如20/200*100=10 也就是10% 把这个10传给页面 把有颜色的矩形宽度设置为10%的宽度就行了

C. PHP命令行下如何实现动态进度条

echo "Progress : "; // 5 characters of padding at the end
for ($i=0 ; $i<=100 ; $i++) {
echo "\033[5D"; // Move 5 characters backward
echo str_pad($i, 3, ' ', STR_PAD_LEFT) . " %"; // Output is always 5 characters
long
sleep(1); // wait for a while, so we see the animation
}
https://www.mmbyte.com/article/1791.html

D. php 导入导出怎么做成有进度条

先获取整体任务,然后以一个维度来量化,再随时取当前进度,除以整体的,再化整

比如一个文件内有x行要读入,那么虽然每行内容大小不一,但可以看做计算完每行算完成总体进度1/x

那么如果要每处理完一行,就要响应不断的查询和进行一个输出,会影响性能的,而且你的导入方式必须能够量化每一步

比如这样
$file_size=文件内数据行数;
$current=0; //第一行,开始

while (没处理完)
{
导入一行;
$current++;
输出 $current/$file_size * 100;
//继续
}

显而易见,这得你的处理是逐步的....如果你是用某种现成的直接导入导出文件的函数,你根本不会获取到中间执行的过程.

E. PHP圆形进度条怎么做

一般实现下载进度条常用的两种解决方案是:一种是需要用socket保持与客户端通信,返回已下载的数据大小,然后可以JS+css显示下载速度,以及进度条之类;二种是php与flash交互,显示进度条。另外PHP5.4起 开始支持 进度条 Upload progress,你可以了解下!

F. 大神,ThinkPHP 上传文件进度条怎么实现的

Web Uploader
这个插件是网络出的,有进度条,兼容ie7及以上。
原理就是ajax上传,会返回1-100的数值,根据这个值来操作进度条。如果还有不明白的话,你可以在后盾人看看视频找找答案,有空多看看时间长了,慢慢就明白了,希望能帮到你,给个采纳吧谢谢

G. php 文件上传,如何实现进度条功能

用flash文件上传插件
如:http://ke..com/view/1332553.html?wtp=tt
php创始者也写了一个php的扩展可以实现,麻烦,不如flash上传插件简单,qq,的相册都用flash传

H. php中怎么实现读取数据进度条功能

<?php//防止执行超时set_time_limit(0);//清空并关闭输出缓存ob_end_clean();//需要循环的数据for($i = 0; $i < 188; $i++){ $users[] = 'Tom_' . $i;}//计算数据的长度$total = count($users);//显示的进度条长度,单位 px$width = 500;//每条记录的操作所占的进度条单位长度$pix = $width / $total;//默认开始的进度条百分比$progress = 0;?><html><head><title>动态显示服务器运行程序的进度条</title><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /><style>body,div input { font-family: Tahoma; font-size: 9pt}</style><script language="JavaScript"> <!-- function updateProgress(sMsg, iWidth) { document.getElementById("status").innerHTML = sMsg; document.getElementById("progress").style.width = iWidth + "px"; document.getElementById("percent").innerHTML = parseInt(iWidth / <?php echo $width; ?> * 100) + "%"; } --> </script></head><body> <div style="margin:50px auto; padding: 8px; border: 1px solid gray; background: #EAEAEA; width: <?php echo $width+8; ?>px"> <div style="padding: 0; background-color: white; border: 1px solid navy; width: <?php echo $width; ?>px"> <div id="progress" style="padding: 0; background-color: #FFCC66; border: 0; width: 0px; text-align: center; height: 16px"></div> </div> <div id="status"></div> <div id="percent" style="position: relative; top: -30px; text-align: center; font-weight: bold; font-size: 8pt">0%</div> </div><?phpflush(); //将输出发送给客户端浏览器foreach($users as $user){ // 在此处使用空循环模拟较为耗时的操作,实际应用中需将其替换; // 如果你的操作不耗时,我想你就没必要使用这个脚本了 :) for($i = 0; $i < 1000000; $i++) { } ?><script language="JavaScript"> updateProgress("正在操作用户 <?php echo $user; ?> ....", <?php echo min($width, intval($progress)); ?>);</script><?php flush(); //将输出发送给客户端浏览器,使其可以立即执行服务器端输出的 JavaScript 程序。 $progress += $pix;} //end foreach?><script language="JavaScript"> //最后将进度条设置成最大值 $width,同时显示操作完成 updateProgress("操作完成!", <?php echo $width; ?>);</script><?phpflush();?></body></html

I. PHP中使用Session配合Javascript实现文件上传进度条功能

Web应用中常需要提供文件上传的功能。典型的场景包括用户头像上传、相册图片上传等。当需要上传的文件比较大的时候,提供一个显示上传进度的进度条就很有必要了。
在PHP
5.4以前,实现这样的进度条并不容易,主要有三种方法:
1.使用Flash,
Java,
ActiveX
2.使用PHP的APC扩展
3.使用HTML5的File
API
第一种方法依赖第三方的浏览器插件,通用性不足,且易带来安全隐患。不过由于Flash的使用比较广泛,因此还是有很多网站使用Flash作为解决方案。
第二种方法的不足在于,它需要安装PHP的APC扩展库,要求用户能够控制服务器端的配置。另外,如果安装APC仅仅是为了实现一个上传进度条,那么显然有点杀鸡用牛刀的意思。
第三种方法应该是最为理想的方法,不需要服务器端的支持,仅在浏览器端使用Javascript即可。但是由于HTML5标准尚未确立,各浏览器厂商的支持也不相同,所以暂时这种方法还难以普及。
PHP
5.4中引入的基于session的上传进度监视功能(session.upload_progress),它提供了一个服务器端的上传进度监视解决方案。升级到PHP
5.4之后,可以不必安装APC扩展,仅使用原生PHP和前端的Javascript即可实现上传进度条。
下面我们就详细介绍一下
PHP
5.4
的这个
session.upload_progress
新特性。
原理介绍
当浏览器向服务器端上传一个文件时,PHP将会把此次文件上传的详细信息(如上传时间、上传进度等)存储在session当中。然后,随着上传的进行,周期性的更新session中的信息。这样,浏览器端就可以使用Ajax周期性的请求一个服务器端脚本,由该脚本返回session中的进度信息;浏览器端的Javascript即可根据这些信息显示/更新进度条了。
那么,文件上传信息具体是如何存储的?我们要如何访问它呢?下面我们来详细说明。
PHP
5.4
中引入了一些配置项(在php.ini中进行设置)
复制代码
代码如下:
session.upload_progress.enabled
=
"1"
session.upload_progress.cleanup
=
"1"
session.upload_progress.prefix
=
"upload_progress_"
session.upload_progress.name
=
"PHP_SESSION_UPLOAD_PROGRESS"
session.upload_progress.freq
=
"1%"
session.upload_progress.min_freq
=
"1"
其中enabled控制upload_progress功能的开启与否,默认开启;cleanup
则设置当文件上传的请求提交完成后,是否清除session的相关信息,默认开启。
prefix

name
两项用来设置进度信息在session中存储的变量名/键名。关于这两项的详细使用见下文。
freq

min_freq
两项用来设置服务器端对进度信息的更新频率。合理的设置这两项可以减轻服务器的负担。
在上传文件的表单中,需要为该次上传设置一个标识符,并在接下来的过程中使用该标识符来引用进度信息。具体的,在上传表单中需要有一个隐藏的input,它的name属性为php.ini中
session.upload_progress.name
的值;它的值为一个由你自己定义的标识符。如下:
复制代码
代码如下:
<input
type="hidden"

name="<?php
echo
ini_get('session.upload_progress.name');
?>"

value="test"
/>
接到文件上传的表单后,PHP会在$_SESSION变量中新建键,键名是一个将session.upload_progress.prefix的值与上面你自定义的标识符连接后得到的字符串,可以这样得到:
复制代码
代码如下:
$name
=
ini_get('session.upload_progress.name');
$key
=
ini_get('session.upload_progress.prefix')
.
$_POST[$name];
$_SESSION[$key];
//
这里就是此次文件上传的进度信息了

J. php显示进度条

如果确实想精确的处理下载进度条的话,两种方案:
第一种是需要用socket保持与客户端通信,返回已下载的数据大小,然后可以显示下载速度,以及进度条之类。
第二种是php与flash交互,显示进度条。

否则的可以显示一个模拟进度条,如果满足需求的话。
满意请采纳。

阅读全文

与php实现进度条相关的资料

热点内容
用纸做解压玩具不用浇水 浏览:582
谷轮压缩机序列号 浏览:734
牛顿插值法编程 浏览:364
php多用户留言系统 浏览:727
安卓和苹果如何切换流量 浏览:703
怎么知道dns服务器是多少 浏览:976
5995用什么简便算法脱式计算 浏览:918
电脑上如何上小米云服务器地址 浏览:921
手机资料解压密码 浏览:444
44引脚贴片单片机有哪些 浏览:692
阿里程序员脑图 浏览:189
广东编程猫学习班 浏览:708
上海数控编程培训学校 浏览:313
怎么下载我的解压神器 浏览:634
lib文件无用代码会编译吗 浏览:28
我的世界嗨皮咳嗽服务器怎么下 浏览:1002
mvn命令顺序 浏览:978
车贷还完多少时间解压 浏览:965
java页面开发 浏览:820
学编程的小发明 浏览:25