PHP+jQuery+Ajax實(shí)現(xiàn)多圖片上傳效果
今天我給大家分享的是在不刷新頁面的前提下,使用PHP+jQuery+Ajax實(shí)現(xiàn)多圖片上傳的效果。用戶只需要點(diǎn)擊選擇要上傳的圖片,然后圖片自動(dòng)上傳到服務(wù)器上并展示在頁面上。
HTML
我們在頁面上放置一個(gè)form表單,使用post提交到后臺php處理程序upload.php,注意enctype屬性設(shè)置要支持文件上傳。#preview用來顯示上傳完畢后的圖片。關(guān)于css樣式設(shè)置本文不加說明,請參照下載包的源碼。
<form id="imageform" method="post" enctype="multipart/form-data" action="upload.php">
<div id="up_status" style="display:none"><img src="loader.gif" alt="uploading"/></div>
<div id="up_btn" class="btn">
<span>添加圖片</span>
<input id="photoimg" type="file" name="photoimg">
</div>
</form>
<p>最大100KB,支持jpg,gif,png格式。</p>
<div id="preview"></div>
jQuery
本實(shí)例基于jQuery,因此必須在頁面中載入jquery庫以及jquery.wallform.js。
<script type="text/javascript" src="jquery.min.js"></script>
<script type="text/javascript" src="jquery.wallform.js"></script>
當(dāng)點(diǎn)擊按鈕“添加圖片”后,彈出選擇文件對話框,選擇要上傳的圖片后,觸發(fā)change事件。然后表單#imageform調(diào)用jquery.wallform.js的ajaxForm()方法,將表單數(shù)據(jù)提交給后臺PHP處理,并根據(jù)返回結(jié)果處理頁面元素的展示。如果上傳成功,圖片會一張張排列顯示在頁面上。關(guān)于ajaxForm()的使用可以參照本站文章:Ajax表單提交插件jqery form。
$(function(){
$('#photoimg').die('click').live('change', function(){
var status = $("#up_status");
var btn = $("#up_btn");
$("#imageform").ajaxForm({
target: '#preview',
beforeSubmit:function(){
status.show();
btn.hide();
},
success:function(){
status.hide();
btn.show();
},
error:function(){
status.hide();
btn.show();
} }).submit();
});
});
PHP
upload.php處理圖片上傳,并將上傳好的圖片保存在uploads/目錄,注意該目錄要有寫權(quán)限。首先需要檢測是否為POST方式提交,然后判斷圖片格式、圖片大小是否符合要求,然后使用move_uploaded_file()上傳圖片,并將圖片重命名,格式為:time().rand(100,999)。
$path = "uploads/";
$extArr = array("jpg", "png", "gif");
if(isset($_POST) and $_SERVER['REQUEST_METHOD'] == "POST"){
$name = $_FILES['photoimg']['name'];
$size = $_FILES['photoimg']['size'];
if(empty($name)){
echo '請選擇要上傳的圖片';
exit;
}
$ext = extend($name);
if(!in_array($ext,$extArr)){
echo '圖片格式錯(cuò)誤!';
exit;
}
if($size>(100*1024)){
echo '圖片大小不能超過100KB';
exit;
}
$image_name = time().rand(100,999).".".$ext;
$tmp = $_FILES['photoimg']['tmp_name'];
if(move_uploaded_file($tmp, $path.$image_name)){
echo '<img src="'.$path.$image_name.'" class="preview">';
}else{
echo '上傳出錯(cuò)了!';
}
exit;
}
//獲取文件類型后綴
function extend($file_name){
$extend = pathinfo($file_name);
$extend = strtolower($extend["extension"]);
return $extend;
}
當(dāng)然,實(shí)際應(yīng)用中,可以與數(shù)據(jù)庫以及用戶中心結(jié)合,將用戶上傳的圖片保存在數(shù)據(jù)表中,具體應(yīng)用大家可以自行研究。
以上就是本文給大家分享的全部內(nèi)容了,希望大家能夠喜歡。
- jQuery+ThinkPHP實(shí)現(xiàn)圖片上傳
- jquery+ajax實(shí)現(xiàn)上傳圖片并顯示上傳進(jìn)度功能【附php后臺接收】
- PHP結(jié)合jquery ajax實(shí)現(xiàn)上傳多張圖片,并限制圖片大小操作示例
- jQuery+PHP實(shí)現(xiàn)上傳裁剪圖片
- thinkphp jquery實(shí)現(xiàn)圖片上傳和預(yù)覽效果
- JQuery PHP圖片在線裁剪實(shí)例
- php+flash+jQuery多圖片上傳源碼分享
- jquery+php+ajax顯示上傳進(jìn)度的多圖片上傳并生成縮略圖代碼
- PHP結(jié)合JQueryJcrop實(shí)現(xiàn)圖片裁切實(shí)例詳解
- jQuery+PHP實(shí)現(xiàn)圖片上傳并提交功能
相關(guān)文章
jQuery動(dòng)態(tài)添加元素后元素注冊事件失效解決
這篇文章主要介紹了jQuery動(dòng)態(tài)添加元素后元素注冊事件失效解決,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下2022-08-08jQuery判斷網(wǎng)頁是否已經(jīng)滾動(dòng)到瀏覽器底部的實(shí)現(xiàn)方法
最近做項(xiàng)目遇到這樣的需求,要求基于jq判斷網(wǎng)頁是否已經(jīng)滾動(dòng)到瀏覽器底部了,下面小編給大家分享實(shí)例代碼,需要的朋友參考下吧2017-10-10在IE 瀏覽器中使用 jquery的fadeIn() 效果 英文字符字體加粗
在IE 瀏覽器中使用 jquery的fadeIn() 效果 英文字符字體加粗的解決方法分享。2011-06-06給artDialog 5.02 增加ajax get功能詳細(xì)介紹
本文將詳細(xì)介紹給artDialog 5.02 增加ajax get功能的方法,按興趣的朋友可以參考2012-11-11基于jQuery實(shí)現(xiàn)滾動(dòng)刷新效果
這篇文章主要為大家詳細(xì)介紹了基于jQuery實(shí)現(xiàn)滾動(dòng)刷新效果,使用Ajax獲取后臺數(shù)據(jù)更新前端頁面,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-01-01jQuery插件datalist實(shí)現(xiàn)很好看的input下拉列表
本文給大家分享的是使用jQuery實(shí)現(xiàn)的房HTML5中的一個(gè)好看的input框很好看的下拉列表--datalist,兼容性非常不錯(cuò),這里推薦給大家,有需要的小伙伴可以參考下。2015-07-07jQuery .tmpl(), .template()學(xué)習(xí)資料小結(jié)
昨晚無意中發(fā)現(xiàn)一個(gè)有趣的jQuery插件.tmpl(),其文檔在這里。2011-07-07jquery使用canvas標(biāo)簽繪制驗(yàn)證碼
這篇文章主要為大家詳細(xì)介紹了Jquery中用canvas標(biāo)簽繪制驗(yàn)證碼,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-10-10基于PHP和Mysql相結(jié)合使用jqGrid讀取數(shù)據(jù)并顯示
jqGrid可以動(dòng)態(tài)讀取和加載外部數(shù)據(jù),本文將結(jié)合PHP和Mysql給大家講解如何使用jqGrid讀取數(shù)據(jù)并顯示,以及可以通過輸入關(guān)鍵字查詢數(shù)據(jù)的ajax交互過程2015-12-12