当前位置: 首页 > 图文教程 > 网络编程 > AJAX技术 > php+ajax文件上传进度条

AJAX技术
用AJAX技术聚合RSS
Ajax 网址备忘
用javascript实现页面无刷新更新数据
ajax应用
AJAX入门之XMLHttpRequest慨述
AJAX入门之深入理解JavaScript中的函数
XMLHttpRequest of ajax
ajax 检测用户名是否被占用
开始研究Ajax. 第一天
ajax 不错的应用
Ajax技术(WEB无刷新提交数据)-
AJAX应用之注册用户即时检测
AJAX初体验之上手篇
ASP小偷程序如何利用XMLHTTP实现表单的提交
AJAX打造博客无刷新搜索
Flash & Ajax 操作 XML 实例:无刷新分页
Ajax 汇总以及初步评价
基于 Ajax 的无限级菜单
AJAX请求类
发布三个ajax相关的函数,包括无刷新提交表单等

AJAX技术 中的 php+ajax文件上传进度条


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-11-03   浏览: 27 ::
收藏到网摘: n/a

 
代码分为以下部分:
demo.php - 上传过程处理
PLAIN TEXTPHP:
<?php
 
include ’UploadProgressMeter.class.php’;
 
$fileWidget = new UploadProgressMeter();
 
if ($fileWidget->uploadComplete()) {
        // 上传完毕的时候,从iframe发送一个js到主窗口表示一切ok
        echo $fileWidget->finalStatus();
 
        // 处理上传后的文件...
 
        exit;
}
?> 
demoserver.php - ajax的服务端js,使用Pear:HTML_AJAX,直接调用UploadProgressMeterStatus类
PLAIN TEXTHTML:
<script src="http://www.ooso.net/demoserver.php?client=main,request,httpclient,dispatcher,json,util" type="text/javascript"></script>
<script src="http://www.ooso.net/demoserver.php?stub=UploadProgressMeterStatus" type="text/javascript"></script>
<?php echo $fileWidget->renderIncludeJs(); ?> 
进度条的样式表
PLAIN TEXTCSS:
.progressBar {
  position: relative;
  padding: 2px;
  width: 300px;
  height: 40px;
  font-size: 14px;
}
.progressBar .background {
  border: solid 1px black;
  width: 270px;
  height: 20px;
}
.progressBar .bar {
  position: relative;
  background-color: blue;
  width: 0px;
  height: 20px;

表单部分
PLAIN TEXTHTML:
<form action="demo.php" method="post" enctype="multipart/form-data">renderFormExtra(); ?>>
<?php echo $fileWidget->renderHidden(); ?></form><form action="demo.php" method="post" enctype="multipart/form-data"><label>Select File: </label>
<div><?php echo $fileWidget->render(); ?>
<?php echo $fileWidget->renderProgressBar(); ?></div>
</form>