ajax对象有成员upload,该upload成员是一个对象,本身有onprogress事件
该事件每间隔100ms左右就执行一次,执行的时候可以感知附件已经上传和总大小等信息,
使得“已经上传大小”和“总大小”做对比可以获得上传附件的百分比,进而就可以设置进度条。
![Image](https://box.kancloud.cn/648ac7585fa0ad6a3067efa3ba1c384d_485x253.png)
利用新技术FormData表单数据对象,可以实现快速收集表单信息。
FormData是[HTML5](http://lib.csdn.net/base/html5 "HTML5知识库")的新技术,在主流浏览器都可以正常使用。
可以利用FormData实现附件信息的收集:普通表单域 和 上传文件域 均可以收集
FormData使用注意事项:
1,无需使用setRequestHeader()方法
2\.要求每个表单域里面必须有name属性
3\.表单域内内部有特殊符号($=&)无需编码
4\.在form标签里边无需设置enctype=”multipart/form-data”属性(即使有上传文件域也不需要设置)
<script type="text/javascript">
//javascript+ajax无刷新方式form表单提交
window.onload = function(){
var fm = document.getElementsByTagName('form')\[0\];
//表单提交事件
fm.onsubmit = function(evt){
//① 收集用户输入的表单域信息\[FormData\]
var fd = new FormData(fm);//普通表单域 + 上传文件域信息
//② 并把收集的信息提交给服务器端\[ajax\]
var xhr = new XMLHttpRequest();
xhr.onreadystatechange = function(){
if(xhr.readyState==4){
alert(xhr.responseText);
}
}
xhr.upload.onprogress = function(evt){
//该事件每间隔100ms左右就执行一次,
//并可以通过事件对象感知附件信息
//附件已经上传大小
var lod = evt.loaded;
//附件总大小
var tal = evt.total;
//上传百分比
var per = Math.floor((lod/tal)\*100) + "%";
//给son的div设置宽度百分比 document.getElementById('son').innerHTML= per;
document.getElementById('son').style.width = per;
}
xhr.open('post','./06.php');
xhr.send(fd);
//阻止浏览器form表单的提交动作
evt.preventDefault();
}
}
</script>
<style type="text/css">
\#pat {width:460px; height:40px;border:4px solid blue;}
\#son {width:0; height:100%; background-color:lightblue;}
</style>
</head>
<body>
<h2>用户注册(无刷新方式附件上传)</h2>
<form method="post" action="./1001.php">
<p>用户名:<input type="text" id="mingzi" name="username" /></p>
<p>密码:<input type="password" id="mima" name="userpwd" /></p>
<p>邮箱:<input type="text" id="youxiang" name="useremail" /></p>
<div id="pat"><div id="son"></div></div>
<p>头像:<input type="file" id="touxiang" name="userpic" /></p>
<p><input type="submit" value="注册" /></p>
</form>
</body>
<?php
if($\_FILES\['userpic'\]\['error'\]>0){
echo "false";
}else {
echo "true";
}
?>
- PHP
- 页面跳转
- 数据类型和运算符
- 整形
- 浮点型
- 字符串型
- 布尔型
- 判断数据类型
- 传值
- 类型转换
- 常量
- 进制转换
- 运算符
- 各种结构
- 数组
- 分类
- 创建
- 多维数组
- 数组操作函数
- 数组指针
- 排序
- 数组交换需要注意的
- 函数
- 创建函数
- 参数传递
- 参数数量问题
- 返回值
- 可变函数
- 匿名函数
- 冒泡,选择,二分
- 变量的作用域
- 局部作用域中使用全局
- use
- 有关函数的系统函数
- 递归
- 递推(迭代)
- 面向对象
- 类和对象
- 值传递
- 引用传递
- 成员
- 构造和析构调用上级同类方法
- 重写
- 最终类
- 最终方法
- 设计模式
- 抽象类
- 抽象方法
- 抽象类和抽象方法的细节
- 重载
- 接口
- 类和接口的总结
- 自动加载
- 克隆
- 对象的遍历
- 内置标准类
- 其他类型转对象类型
- 类型约束
- 魔术方法
- static关键字
- 命名空间
- 子级空间
- 引入机制
- 公共空间
- 使用注意
- 错误处理
- 错误的触发
- 错误报告的显示
- 错误日志的记录问题
- 自定义错误处理器
- 异常抛出
- 文件锁
- 文件处理
- 序列化与反序列化
- 目录操作
- 文件操作
- 文件上传
- $_FILFS
- 多文件上传处理
- 绘图技术
- 创建画布资源
- 操作画布
- 导出
- 销毁资源
- 验证码
- 补充文件居中
- 在图像上写入一行TTF字体的文本
- 获得图像相关信息
- 水印
- 等比例缩放
- 常见错误
- HTTP协议
- URL的构成
- 请求
- 防盗链
- 响应
- 使用header()禁用缓存
- 下载文件的HTTP响应头
- 文件下载
- HTTPS
- 会话技术
- cookie
- session
- PHP操作MySQL函数
- 登录
- 一些函数
- 从结果集中取出一行数据
- 获取行数,列数,字段名
- 安全
- 缓存
- 补充
- MySQL
- 语法
- 备份和恢复
- 注释
- 语句行
- 字符集
- 校验级
- 存储引擎
- 数据库操作
- 创建数据库
- 删除数据库
- 显示数据库
- 修改数据库
- 数据类型
- 整数类型
- 小数类型
- 日期时间型
- 字符和文本型
- enum类型
- set类型
- 时间类型
- 表操作
- 创建
- 索引
- 约束
- 表选项列表
- 表的其他语句
- 视图语法
- 增删改查
- 插入数据(增)
- 删除数据(删)
- 修改数据(改)
- 查询(查)
- 用户和权限管理
- 用户管理
- 权限管理
- PDO
- 与PDO相关的几个类
- 连接数据库
- 使用
- PDO的错误处理
- PDO结果集对象
- pdo结果集对象的常用方法
- PDO预处理
- 常用属性
- mysql编程
- 事务
- 语句块
- mysql中的变量
- (存储)函数
- 存储过程procedure
- 触发器(trigger)
- mysql优化
- 存储引擎
- 字段类型
- 逆范式
- 索引
- Memcache
- 与redis区别
- 安装
- php开启扩展
- php操作memcache
- Key的命名
- 有效期
- 各种数据类型存储
- 删除
- 第三个参数压缩作用
- 其他相关操作方法
- 终端命令操作方式
- 获取memcache统计信息
- Git
- 创建一个git仓库
- 添加
- 修改文件
- 删除文件
- 克隆
- 个人网站
- Ajax
- 发起请求
- 接受响应
- 常用属性和方法
- get和post
- get
- post
- 同步和异步
- 什么时候使用同步请求?
- 分页
- xml的接收和处理
- JSON
- 无刷新表单提交和进度条
- JQuery操作ajax
- iframe
- 邮件
- 介绍
- 发送邮件
- 直投邮件
- 中转邮件发送
- phpmailer
- 正则表达
- 简单使用
- preg_match()
- 正则内容
- 定义字符集
- 特别字符集
- 组合字符集
- 限制字符
- 模式修正符
- 进行全局匹配