Heim Backend-Entwicklung PHP-Problem So löschen Sie mehrere Bild-Upload-Vorschauen in PHP

So löschen Sie mehrere Bild-Upload-Vorschauen in PHP

Apr 21, 2023 am 09:08 AM

Mit der kontinuierlichen Entwicklung des Internets müssen immer mehr Websites die Funktion zum Hochladen mehrerer Bilder unterstützen. Bei der Implementierung der Funktion zum Hochladen mehrerer Bilder müssen Websites auch Vorschau- und Löschfunktionen unterstützen, um den Anforderungen besser gerecht zu werden die Bedürfnisse der Benutzer. In diesem Artikel wird erläutert, wie Sie mit PHP mehrere Funktionen zum Hochladen, Vorsehen und Löschen von Bildern implementieren.

1. Implementierung der Funktion zum Hochladen mehrerer Bilder

  1. HTML-Code

Erstellen Sie ein Formular im HTML-Code, fügen Sie ein Eingabe-Tag hinzu, das Typattribut ist Datei, dieses Tag ermöglicht es dem Benutzer, das zu erstellende Bild auszuwählen hochgeladen und muss gleichzeitig hinzugefügt werden. Ein enctype-Attribut mit dem Wert „multipart/form-data“, das angibt, dass das Formular im Multipart/form-data-Format übermittelt wird.

<form action="upload.php" method="post" enctype="multipart/form-data">
  <input type="file" name="image[]" multiple>
  <input type="submit" name="submit" value="上传">
</form>
Nach dem Login kopieren
  1. PHP-Code

Der PHP-Code akzeptiert über das Formular übermittelte Bilddateien und lädt die Dateien in das angegebene Verzeichnis auf dem Server hoch.

// 设置上传目录
$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;
  }
}
Nach dem Login kopieren

2. Implementierung der Vorschaufunktion

Zuerst müssen Sie die erfolgreich hochgeladenen Bilder auf der Seite anzeigen. Hier wird eine foreach-Schleife verwendet, um die hochgeladenen Bilder zu durchlaufen, und das HTML-img-Tag wird verwendet, um sie anzuzeigen.

<div class="uploaded-images">
  <?php foreach ($fileNames as $fileName) { ?>
    <img src="./uploads/<?php echo $fileName ?>">
  <?php } ?>
</div>
Nach dem Login kopieren

Der obige Code zeigt alle erfolgreich hochgeladenen Bilder an, aber diese Methode kann einige interaktive Vorgänge, wie z. B. Bewegen der Maus, Klicken usw., nicht ausführen. Daher müssen wir auch JavaScript verwenden, um diese Effekte zu erzielen. Hier verwenden wir jQuery, um die entsprechenden Funktionen schnell zu implementieren.

  1. Zeigen Sie die Schaltfläche „Löschen“ an, wenn die Maus über dem Bild schwebt.

Verwenden Sie CSS, um eine Schaltfläche zum Löschen festzulegen und diese Schaltfläche anzuzeigen, wenn die Maus über dem Bild schwebt.

.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;
}
Nach dem Login kopieren
  1. Führen Sie den Löschvorgang aus, wenn Sie auf die Schaltfläche „Löschen“ klicken.

Nach dem Klicken auf die Schaltfläche „Löschen“ muss das entsprechende Bild vom Server gelöscht und von der HTML-Seite entfernt werden. Hier verwenden wir Ajax, um asynchrone Löschvorgänge zu implementieren.

<div class="image-container">
  <img class="image" src="./uploads/<?php echo $fileName ?>">
  <div class="delete-btn" data-filename="<?php echo $fileName ?>">x</div>
</div>
Nach dem Login kopieren
// 点击删除按钮时触发
$('.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();
    }
  });
});
Nach dem Login kopieren

3. Implementierung der Löschfunktion

Wenn auf die Schaltfläche „Löschen“ geklickt wird, wird eine asynchrone Anfrage ausgelöst, um das entsprechende Bild vom Server zu löschen. Wir können vor dem Löschen einige Prüfsummenabfragen durchführen und entsprechende Promptinformationen ausgeben, wenn ein Fehler auftritt.

  1. Löschüberprüfung

Vor dem Löschen müssen wir überprüfen, ob das Bild vorhanden ist. Wenn es nicht vorhanden ist, kann der Löschvorgang nicht durchgeführt werden.

$file = $dir . $_POST['fileName'];
if (file_exists($file)) {
  // 删除文件
  unlink($file);
  echo 'success';
} else {
  echo '文件不存在';
}
Nach dem Login kopieren
  1. Eingabeaufforderung löschen

Wir können Ajax verwenden, um den Statuscode an das Frontend zurückzugeben, nachdem der Löschvorgang fehlgeschlagen oder erfolgreich war, und die entsprechenden Eingabeaufforderungsinformationen anzuzeigen. Hier ist ein einfaches und benutzerfreundliches Eingabeaufforderungsfeld, das die Popup-Fensterkomponente in Bootstrap verwendet.

<!-- 弹出窗口模板 -->
<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>
Nach dem Login kopieren
$.ajax({
  url: '/delete.php',
  type: 'POST'
  data: {fileName: fileName},
  success: function(response) {
    if (response === 'success') {
      // 显示删除成功提示
      $('.delete-success').removeClass('hidden');
    } else {
      // 显示删除失败提示
      $('.delete-failed').removeClass('hidden');
    }
  }
});
Nach dem Login kopieren

Bisher haben wir die Funktionen zum Hochladen, Vorschau und Löschen mehrerer Bilder erfolgreich implementiert und gleichzeitig entsprechende Überprüfungen und Eingabeaufforderungen durchgeführt. Das Obige ist nur eine kurze Einführung in die Implementierung. Wenn Sie diese Funktionen verwenden müssen, können Sie entsprechend Ihren Anforderungen entsprechende Änderungen und Erweiterungen vornehmen.

Das obige ist der detaillierte Inhalt vonSo löschen Sie mehrere Bild-Upload-Vorschauen in PHP. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Wie man alles in Myrise freischaltet
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Wie benutze ich asynchrone Aufgaben in PHP für nicht blockierende Operationen? Wie benutze ich asynchrone Aufgaben in PHP für nicht blockierende Operationen? Mar 10, 2025 pm 04:21 PM

In diesem Artikel werden die asynchronen Aufgabenausführung in PHP untersucht, um die Reaktionsfähigkeit der Webanwendungen zu verbessern. Es enthält Methoden wie Nachrichtenwarteschlangen, asynchrone Frameworks (ReactPHP, SWOOLE) und Hintergrundprozesse, die die Best Practices für Effiziene betonen

Wie implementieren Sie Nachrichtenwarteschlangen (Rabbitmq, Redis) in PHP? Wie implementieren Sie Nachrichtenwarteschlangen (Rabbitmq, Redis) in PHP? Mar 10, 2025 pm 06:15 PM

In diesem Artikel werden die Nachrichtenwarteschlangen in PHP unter Verwendung von Rabbitmq und Redis implementiert. Es vergleicht ihre Architekturen (AMQP vs. In-Memory), Merkmale und Zuverlässigkeitsmechanismen (Bestätigungen, Transaktionen, Persistenz). Best Practices für Design, Fehler

Was sind die neuesten PHP -Codierungsstandards und Best Practices? Was sind die neuesten PHP -Codierungsstandards und Best Practices? Mar 10, 2025 pm 06:16 PM

In diesem Artikel werden aktuelle PHP-Codierungsstandards und Best Practices untersucht und sich auf PSR-Empfehlungen (PSR-1, PSR-2, PSR-4, PSR-12) konzentrieren. Es betont die Verbesserung der Code -Lesbarkeit und -wartbarkeit durch konsistentes Styling, sinnvolles Namen und EFF

Wie arbeite ich mit PHP -Erweiterungen und PECL? Wie arbeite ich mit PHP -Erweiterungen und PECL? Mar 10, 2025 pm 06:12 PM

In diesem Artikel wird die Installation und Fehlerbehebung von PHP -Erweiterungen in der Installation und Fehlerbehebung beschrieben und sich auf PECL konzentriert. Es deckt Installationsschritte (Feststellung, Herunterladen/Kompilieren, Aktivieren, Neustarten des Servers), Fehlerbehebungstechniken (Überprüfung von Protokollen, Überprüfung der Installation, Fehlerbehebungstechniken

Wie kann man Reflection verwenden, um den PHP -Code zu analysieren und zu manipulieren? Wie kann man Reflection verwenden, um den PHP -Code zu analysieren und zu manipulieren? Mar 10, 2025 pm 06:12 PM

In diesem Artikel werden die Reflexions -API von PHP erläutert und die Laufzeitinspektion und Manipulation von Klassen, Methoden und Eigenschaften ermöglicht. Es beschreibt gemeinsame Anwendungsfälle (Dokumentationserzeugung, ORMs, Abhängigkeitsinjektion) und Vorsichtsmaßnahmen gegen Leistungsüberhitzungen

Wie verwende ich Speicheroptimierungstechniken in PHP? Wie verwende ich Speicheroptimierungstechniken in PHP? Mar 10, 2025 pm 04:23 PM

Dieser Artikel befasst sich mit der PHP -Speicheroptimierung. Es beschreibt Techniken wie die Verwendung geeigneter Datenstrukturen, die Vermeidung unnötiger Objekterstellung und die Verwendung effizienter Algorithmen. Gemeinsame Memory -Leck -Quellen (z. B. nicht abgestellte Verbindungen, Global V

Wie bleibe ich mit dem PHP-Ökosystem und der Gemeinschaft auf dem Laufenden? Wie bleibe ich mit dem PHP-Ökosystem und der Gemeinschaft auf dem Laufenden? Mar 10, 2025 pm 06:16 PM

In diesem Artikel werden Strategien untersucht, um im PHP -Ökosystem auf dem neuesten Stand zu bleiben. Es betont die Verwendung offizieller Kanäle, Community-Foren, Konferenzen und Open-Source-Beiträge. Der Autor hebt die besten Ressourcen zum Erlernen neuer Funktionen und a hervor

PHP 8 JIT (Just-in-Time) -Kompilation: Wie es die Leistung verbessert. PHP 8 JIT (Just-in-Time) -Kompilation: Wie es die Leistung verbessert. Mar 25, 2025 am 10:37 AM

Die JIT -Kompilierung von PHP 8 verbessert die Leistung, indem häufig ausgeführte Code in den Maschinencode zusammengestellt wird, um Anwendungen mit schweren Berechnungen zugute und die Ausführungszeiten zu reduzieren.

See all articles