首頁 後端開發 PHP問題 php怎麼實現多圖上傳預覽刪除

php怎麼實現多圖上傳預覽刪除

Apr 21, 2023 am 09:08 AM

隨著網路的不斷發展,越來越多的網站需要支援多圖上傳功能,而對於網站來說,實現多圖上傳功能的同時還需要支援預覽和刪除功能,這樣才能更好地滿足用戶的需求。本文將介紹如何使用PHP實作多圖上傳、預覽和刪除功能。

一、多圖上傳功能的實作

  1. HTML程式碼

在HTML程式碼中建立一個表單,新增一個input標籤,type屬性為file,這個標籤可以讓使用者選擇需要上傳的圖片,同時需要新增一個enctype屬性,值為“multipart/form-data”,表示表單將會使用multipart/form-data格式進行提交。

<form action="upload.php" method="post" enctype="multipart/form-data">
  <input type="file" name="image[]" multiple>
  <input type="submit" name="submit" value="上传">
</form>
登入後複製
  1. PHP程式碼

PHP程式碼接受表單提交的圖片文件,並將文件上傳到伺服器上的指定目錄中,同時還需要進行資料處理和驗證。

// 设置上传目录
$dir = './uploads/';

// 处理上传图片
if (isset($_FILES['image'])) {
  $image = $_FILES['image'];

  // 遍历上传的图片
  foreach ($image['name'] as $key => $name) {
    // 获取图片扩展名
    $ext = pathinfo($name, PATHINFO_EXTENSION);
    // 生成新文件名,避免文件名重复
    $newFileName = uniqid() . '.' . $ext;
    // 将上传的图片移到目标目录
    move_uploaded_file($image['tmp_name'][$key], $dir . $newFileName);
    // 将上传成功的文件名保存到数组中
    $fileNames[] = $newFileName;
  }
}
登入後複製

二、預覽功能的實作

首先需要在頁面中顯示上傳成功的圖片,這裡使用foreach循環遍歷已經上傳的圖片,並使用HTML img標籤將其展示出來。

<div class="uploaded-images">
  <?php foreach ($fileNames as $fileName) { ?>
    <img src="./uploads/<?php echo $fileName ?>">
  <?php } ?>
</div>
登入後複製

上面的程式碼會將上傳成功的所有圖片都展示出來,但是這種方式無法進行一些互動操作,例如滑鼠懸停、點擊等。因此,我們也需要使用JavaScript來實現這些效果,這裡我們使用jQuery來快速實現對應功能。

  1. 滑鼠懸停時顯示刪除按鈕

使用CSS來設定一個刪除按鈕,當滑鼠停留在圖片上時,顯示這個按鈕。

.delete-btn {
  position: absolute;
  top: 5px;
  right: 5px;
  width: 20px;
  height: 20px;
  cursor: pointer;
  background-color: #fff;
  border-radius: 50%;
  opacity: 0.7;
  visibility: hidden;
  transition: opacity ease-in-out 0.2s;
}

.image-container:hover .delete-btn {
  visibility: visible;
}
登入後複製
  1. 點擊刪除按鈕時執行刪除動作

點擊刪除按鈕後,需要將對應的圖片從伺服器上刪除,並將其從HTML頁面中移除。這裡我們使用ajax來實現非同步刪除操作。

<div class="image-container">
  <img class="image" src="./uploads/<?php echo $fileName ?>">
  <div class="delete-btn" data-filename="<?php echo $fileName ?>">x</div>
</div>
登入後複製
// 点击删除按钮时触发
$('.delete-btn').on('click', function() {
  var $container = $(this).closest('.image-container');
  var fileName = $(this).data('filename');
  
  // 发送异步请求删除服务器上的图片
  $.ajax({
    url: '/delete.php',
    type: 'POST',
    data: {fileName: fileName},
    success: function(response) {
      // 移除页面中的图片
      $container.remove();
    }
  });
});
登入後複製

三、刪除功能的實作

在點擊刪除按鈕時,觸發非同步請求將對應的圖片從伺服器上刪除。我們可以在刪除前進行一些校驗和提示,在發生錯誤時給予相應的提示訊息。

  1. 刪除校驗

在刪除之前,我們需要校驗圖片是否存在,如果不存在則無法進行刪除動作。

$file = $dir . $_POST['fileName'];
if (file_exists($file)) {
  // 删除文件
  unlink($file);
  echo 'success';
} else {
  echo '文件不存在';
}
登入後複製
  1. 刪除提示

我們可以透過ajax在刪除失敗或成功後,把狀態碼回傳給前端,並顯示對應的提示訊息。這裡提供一個簡單易用的提示框,使用了Bootstrap中的彈出視窗元件。

<!-- 弹出窗口模板 -->
<div class="alert alert-danger alert-dismissible fade show" role="alert">
  <strong>删除失败!</strong>文件不存在.
  <button type="button" class="close" data-dismiss="alert" aria-label="Close">
    <span aria-hidden="true">&times;</span>
  </button>
</div>
登入後複製
$.ajax({
  url: '/delete.php',
  type: 'POST'
  data: {fileName: fileName},
  success: function(response) {
    if (response === 'success') {
      // 显示删除成功提示
      $('.delete-success').removeClass('hidden');
    } else {
      // 显示删除失败提示
      $('.delete-failed').removeClass('hidden');
    }
  }
});
登入後複製

至此,我們已經成功地實現了多圖上傳、預覽和刪除功能,並同時進行了相應的校驗和提示。以上只是實現方式的簡單介紹,如果你需要使用這些功能,可以根據你的需求來進行相應的修改和擴展。

以上是php怎麼實現多圖上傳預覽刪除的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解鎖Myrise中的所有內容
3 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

如何在PHP中使用異步任務進行非阻滯操作? 如何在PHP中使用異步任務進行非阻滯操作? Mar 10, 2025 pm 04:21 PM

本文探討了PHP中的異步任務執行,以增強Web應用程序響應能力。 它詳細介紹了消息隊列,異步框架(ReactPhp,Swoole)和背景過程等方法,強調了Efficien的最佳實踐

如何在PHP中實現消息隊列(RabbitMQ,REDIS)? 如何在PHP中實現消息隊列(RabbitMQ,REDIS)? Mar 10, 2025 pm 06:15 PM

本文使用RabbitMQ和Redis詳細介紹了PHP中的消息隊列。 它比較了它們的體系結構(AMQP與內存),功能和可靠性機制(確認,交易,持久性)。設計的最佳實踐,錯誤

最新的PHP編碼標準和最佳實踐是什麼? 最新的PHP編碼標準和最佳實踐是什麼? Mar 10, 2025 pm 06:16 PM

本文研究了當前的PHP編碼標準和最佳實踐,重點是PSR建議(PSR-1,PSR-2,PSR-4,PSR-12)。 它強調通過一致的樣式,有意義的命名和EFF提高代碼的可讀性和可維護性

如何使用反射來分析和操縱PHP代碼? 如何使用反射來分析和操縱PHP代碼? Mar 10, 2025 pm 06:12 PM

本文解釋了PHP的反射API,可以實現運行時檢查和對類,方法和屬性的操縱。 它詳細介紹了常見用例(文檔生成,ORM,依賴注入)和針對績效垂涎的警告

我如何處理PHP擴展和PECL? 我如何處理PHP擴展和PECL? Mar 10, 2025 pm 06:12 PM

本文詳細介紹了安裝和故障排除PHP擴展,重點是PECL。 它涵蓋安裝步驟(查找,下載/編譯,啟用,重新啟動服務器),故障排除技術(檢查日誌,驗證安裝,

我如何與PHP生態系統和社區保持最新狀態? 我如何與PHP生態系統和社區保持最新狀態? Mar 10, 2025 pm 06:16 PM

本文探討了在PHP生態系統中保持最新的策略。 它強調利用官方渠道,社區論壇,會議和開源捐款。 作者重點介紹了學習新功能的最佳資源和

PHP 8 JIT(即時)彙編:它如何提高性能。 PHP 8 JIT(即時)彙編:它如何提高性能。 Mar 25, 2025 am 10:37 AM

PHP 8的JIT編譯通過將代碼經常彙編為機器代碼,從而增強了性能,從而使應用程序有益於大量計算並減少執行時間。

如何在PHP中使用內存優化技術? 如何在PHP中使用內存優化技術? Mar 10, 2025 pm 04:23 PM

本文介紹了PHP內存優化。 它詳細介紹了諸如使用適當的數據結構,避免不必要的對象創建以及採用有效算法的技術。 常見的內存洩漏源(例如,未封閉的連接,全局V

See all articles