国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

PHP+jQuery+Ajax實現多圖片上傳效果

2019-11-20 12:56:03
字體:
來源:轉載
供稿:網友

今天我給大家分享的是在不刷新頁面的前提下,使用PHP+jQuery+Ajax實現多圖片上傳的效果。用戶只需要點擊選擇要上傳的圖片,然后圖片自動上傳到服務器上并展示在頁面上。

HTML

我們在頁面上放置一個form表單,使用post提交到后臺php處理程序upload.php,注意enctype屬性設置要支持文件上傳。#preview用來顯示上傳完畢后的圖片。關于css樣式設置本文不加說明,請參照下載包的源碼。

復制代碼 代碼如下:

<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
本實例基于jQuery,因此必須在頁面中載入jquery庫以及jquery.wallform.js。

復制代碼 代碼如下:

<script type="text/javascript" src="jquery.min.js"></script>
<script type="text/javascript" src="jquery.wallform.js"></script>

當點擊按鈕“添加圖片”后,彈出選擇文件對話框,選擇要上傳的圖片后,觸發change事件。然后表單#imageform調用jquery.wallform.js的ajaxForm()方法,將表單數據提交給后臺PHP處理,并根據返回結果處理頁面元素的展示。如果上傳成功,圖片會一張張排列顯示在頁面上。關于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/目錄,注意該目錄要有寫權限。首先需要檢測是否為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 '圖片格式錯誤!';
        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 '上傳出錯了!';
    }
    exit;
}
//獲取文件類型后綴
function extend($file_name){
    $extend = pathinfo($file_name);
    $extend = strtolower($extend["extension"]);
    return $extend;
}

當然,實際應用中,可以與數據庫以及用戶中心結合,將用戶上傳的圖片保存在數據表中,具體應用大家可以自行研究。

以上就是本文給大家分享的全部內容了,希望大家能夠喜歡。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 宁陵县| 法库县| 凤山县| 河间市| 西林县| 会泽县| 汤原县| 榆树市| 台北县| 大同市| 苗栗县| 广丰县| 甘洛县| 建德市| 扎囊县| 钦州市| 元朗区| 饶河县| 庄河市| 游戏| 成安县| 德惠市| 张掖市| 南川市| 肥东县| 鸡泽县| 桐乡市| 策勒县| 崇礼县| 宁城县| 乳山市| 同仁县| 威宁| 德令哈市| 金坛市| 哈巴河县| 深泽县| 综艺| 盐城市| 株洲市| 河西区|