ajax對象有成員upload,該upload成員是一個對象,本身有onprogress事件
該事件每間隔100ms左右就執行一次,執行的時候可以感知附件已經上傳和總大小等信息,
使得“已經上傳大小”和“總大小”做對比可以獲得上傳附件的百分比,進而就可以設置進度條。

利用新技術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()
- 正則內容
- 定義字符集
- 特別字符集
- 組合字符集
- 限制字符
- 模式修正符
- 進行全局匹配