首先实现前端多图选择与实时预览,通过input[file]和FileReader读取文件并展示缩略图;接着使用FormData异步上传至PHP后端,将文件存入temp_uploads目录并返回文件名;然后通过get_temp_images.php扫描目录,页面加载时重新渲染已上传的临时图片,实现刷新回显;最后建议增加文件校验、过期清理和用户隔离机制以提升安全性与稳定性。
实现多图上传并预览,需要前端 JavaScript 实时展示用户选择的图片,后端 PHP 接收文件并临时存储,同时支持页面刷新后回显已上传的临时图片。以下是完整的实现方案。
使用 HTML 的 input[type=file] 支持多选,并通过 JavaScript 读取文件生成预览图。
HTML 部分:
JavaScript 部分(原生 JS):
const input = document.getElementById('imageUpload');
const preview = document.getElementById('previewContainer');
input.addEventListener('change', function() {
preview.innerHTML = ''; // 清空之前的预览
const files = this.files;
Array.from(files).forEach(file => {
if (!file.type.match('image.*')) return;
const reader = new FileReader();
reader.onload = function(e) {
const img = document.createElement('img');
img.src = e.target.result;
img.style.width = '100px';
img.style.height = '100px';
img.style.margin = '5px';
preview.appendChild(img);
};
reader.readAsDataURL(file);
});
});
前端通过 FormData 提交文件,PHP 将其保存到临时目录(如 temp_uploads/),并返回文件名用于后续处理。
改进的 JS:添加上传功能
// 添加上传按钮
//
function uploadImages() {
const files = input.files;
const formData = new FormData();
Array.from(files).forEach(file => {
formData.append('images[]', file);
});
fetch('upload.php', {
method: 'POST',
body: formData
})
.then(response => response.json())
.then(data => {
console.log('上传成功:', data);
loadTempImages(); // 上传后刷新回显
})
.catch(error => {
console.error('上传失败:', error);
});
}
PHP 处理脚本(upload.php):
[], 'error' => []];
$files = $_FILES['images'] ?? null;
if ($files && !empty($files['name'][0])) {
$count = count($files['name']);
for ($i = 0; $i < $count; $i++) {
$tmpName = $files['tmp_name'][$i];
$originalName = $files['name'][$i];
$fileName = uniqid('img_') . '_' . time() . '.' . pathinfo($originalName, PATHINFO_EXTENSION);
$filePath = $uploadDir . $fileName;
if (in_array(mime_content_type($tmpName), ['image/jpeg', 'image/png', 'image/gif'])) {
if (move_uploaded_file($tmpName, $filePath)) {
$response['success'][] = $fileName;
} else {
$response['error'][] = $originalName;
}
} else {
$response['error'][] = $originalName . ' 不是有效图片';
}
}
}
echo json_encode($response);
用户刷新页面后,从服务器获取已上传的临时图片列表并重新生成预览。
JS 加载已上传图片:
function loadTempImages() {
fetch('get_temp_images.php')
.then(response => response.json())
.then(images => {
const preview = document.getElementById('previewContainer');
images.forEach(fileName => {
const img = document.createElement('img');
img.src = 'temp_uploads/' + fileName;
img.da
taset.filename = fileName;
img.style.width = '100px';
img.style.height = '100px';
img.style.margin = '5px';
preview.appendChild(img);
});
});
}
// 页面加载时执行
window.onload = function() {
loadTempImages();
};
get_temp_images.php 获取临时目录中的图片文件名:
注意事项与优化建议
基本上就这些。通过前端预览 + 后端临时存储 + 回显机制,可以实现流畅的多图上传体验。不复杂但容易忽略细节,比如 MIME 校验和路径安全。
# php
# javascript
# java
# html
# js
# 前端
# json
# app
# session
# 后端
# ai
相关文章:
北京网站制作费用多少,建立一个公司网站的费用.有哪些部分,分别要多少钱?
大连网站制作费用,大连新青年网站,五年四班里的视频怎样下载啊?
建站DNS解析失败?如何正确配置域名服务器?
手机怎么制作网站教程步骤,手机怎么做自己的网页链接?
公司网站设计制作厂家,怎么创建自己的一个网站?
一键网站制作软件,义乌购一件代发流程?
如何在宝塔面板中创建新站点?
建站主机助手选型指南:2025年热门推荐与高效部署技巧
企业微网站怎么做,公司网站和公众号有什么区别?
教学网站制作软件,学习*后期制作的网站有哪些?
建站之星安装后如何自定义网站颜色与字体?
建站之星各版本价格是多少?
PHP正则匹配日期和时间(时间戳转换)的实例代码
香港服务器网站搭建教程-电商部署、配置优化与安全稳定指南
成都网站制作公司哪家好,四川省职工服务网是做什么用?
重庆网站制作公司哪家好,重庆中考招生办官方网站?
武汉外贸网站制作公司,现在武汉外贸前景怎么样啊?
整人网站在线制作软件,整蛊网站退不出去必须要打我是白痴才能出去?
实例解析Array和String方法
建站之星如何快速生成多端适配网站?
如何在橙子建站中快速调整背景颜色?
实惠建站价格推荐:2025年高性价比自助建站套餐解析
网站设计制作企业有哪些,抖音官网主页怎么设置?
如何通过IIS搭建网站并配置访问权限?
如何通过主机屋免费建站教程十分钟搭建网站?
建站之星如何优化SEO以实现高效排名?
想学网站制作怎么学,建立一个网站要花费多少?
如何通过VPS搭建网站快速盈利?
开源网站制作软件,开源网站什么意思?
哪家制作企业网站好,开办像阿里巴巴那样的网络公司和网站要怎么做?
北京建设网站制作公司,北京古代建筑博物馆预约官网?
建站主机如何选?高性价比方案全解析
如何通过wdcp面板快速创建网站?
如何在腾讯云服务器快速搭建个人网站?
广州营销型建站服务商推荐:技术优势与SEO优化解析
设计网站制作公司有哪些,制作网页教程?
北京网站制作的公司有哪些,北京白云观官方网站?
北京网站制作公司哪家好一点,北京租房网站有哪些?
深圳网站制作培训,深圳哪些招聘网站比较好?
建站主机系统SEO优化与智能配置核心关键词操作指南
c# Task.ConfigureAwait(true) 在什么场景下是必须的
宝塔建站教程:一键部署配置流程与SEO优化实战指南
制作网站哪家好,cc、.co、.cm哪个域名更适合做网站?
Bpmn 2.0的XML文件怎么画流程图
怎么用手机制作网站链接,dw怎么把手机适应页面变成网页?
如何在Windows虚拟主机上快速搭建网站?
如何做静态网页,sublimetext3.0制作静态网页?
如何快速搭建高效服务器建站系统?
如何快速搭建安全的FTP站点?
建站三合一如何选?哪家性价比更高?
*请认真填写需求信息,我们会在24小时内与您取得联系。