如何使用 AJAX、PHP 和 jQuery 高效上传多个图像?
如何使用 AJAX、PHP 和 jQuery 上传多个图像
使用 AJAX、PHP 和 jQuery 上传多个图像可能是开发 Web 时一项有用的技能应用程序。让我们来看看一个问题及其解决方案,以帮助您实现这一目标:
问题:
“我在使用 AJAX 上传多个图像时遇到问题。这是我的代码已经写道:“
解决方案:
这里的问题不在于上传多个图像,而是在于通过AJAX发送文件数据。要解决此问题,我们需要修改代码并使用 JSON 对文件进行编码:
更新的 HTML:
<div>
更新的 CSS:
#uploads { display: block; position: relative; } #uploads li { list-style: none; } #drop { width: 90%; height: 100px; padding: 0.5em; float: left; margin: 10px; border: 8px dotted grey; } #drop.hover { border: 8px dotted green; } #drop.err { border: 8px dotted orangered; }
已更新JavaScript:
var display = $('#uploads'); // cache `#uploads`, `this` at `$.ajax()` var droppable = $('#drop')[0]; // cache `#drop` selector $.ajaxSetup({ context: display, contentType: 'application/json', dataType: 'json', beforeSend: function (jqxhr, settings) { // pre-process `file` var file = JSON.parse( decodeURIComponent(settings.data.split(/=/)[1]) ); // add `progress` element for each `file` var progress = $( '<progress />', { class: 'file-' + (!!$('progress').length ? $('progress').length : '0'), min: 0, max: 0, value: 0, 'data-name': file.name, } ); this.append(progress, file.name + '<br />'); jqxhr.name = progress.attr('class'); }, }); var processFiles = function processFiles(event) { event.preventDefault(); // process `input[type=file]`, `droppable` `file` var files = event.target.files || event.dataTransfer.files; var images = $.map(files, function (file, i) { var reader = new FileReader(); var dfd = new $.Deferred(); reader.onload = function (e) { dfd.resolveWith(file, [e.target.result]); }; reader.readAsDataURL(new Blob([file], { type: file.type })); return dfd.then(function (data) { return $.ajax({ type: 'POST', url: '/echo/json/', data: { file: JSON.stringify({ file: data, name: this.name, size: this.size, type: this.type, }), }, xhr: function () { // do `progress` event stuff var uploads = this.context; var progress = this.context.find('progress:last'); var xhrUpload = $.ajaxSettings.xhr(); if (xhrUpload.upload) { xhrUpload.upload.onprogress = function (evt) { progress.attr({ max: evt.total, value: evt.loaded }); }; xhrUpload.upload.onloadend = function (evt) { var progressData = progress.eq(-1); console.log(progressData.data('name') + ' upload complete...'); var img = new Image(); $(img).addClass(progressData.eq(-1).attr('class')); img.onload = function () { if (this.complete) { console.log(progressData.data('name') + ' preview loading...'); } }; uploads.append('<br /><li>', img, '</li><br />'); }; } return xhrUpload; }, }) .then(function (data, textStatus, jqxhr) { console.log(data); this.find('img[class=' + jqxhr.name + ']') .attr('src', data.file) .before( '<span>' + data.name + '</span><br />' ); return data; }, function (jqxhr, textStatus, errorThrown) { console.log(errorThrown); return errorThrown; }); }); }); $.when.apply(display, images).then(function () { var result = $.makeArray(arguments); console.log(result.length, 'uploads complete'); }, function err(jqxhr, textStatus, errorThrown) { console.log(jqxhr, textStatus, errorThrown); }); }; $(document).on('change', 'input[name^=file]', processFiles); // process `droppable` events droppable.ondragover = function () { $(this).addClass('hover'); return false; }; droppable.ondragend = function () { $(this).removeClass('hover'); return false; }; droppable.ondrop = function (e) { $(this).removeClass('hover'); var image = Array.prototype.slice.call(e.dataTransfer.files) .every(function (img, i) { return /^image/.test(img.type); }); e.preventDefault(); // if `file`, file type `image` , process `file` if (!!e.dataTransfer.files.length && image) { $(this).find('.drop-area-label').css('color', 'blue').html(function (i, html) { $(this).delay(3000, 'msg').queue('msg', function () { $(this).css('color', 'initial').html(html); }).dequeue('msg'); return 'File dropped, processing file upload...'; }); processFiles(e); } else { // if dropped `file` _not_ `image` $(this).removeClass('hover').addClass('err').find('.drop-area-label').css('color', 'darkred').html(function (i, html) { $(this).delay(3000, 'msg').queue('msg', function () { $(this).css('color', 'initial').html(html) .parent('#drop').removeClass('err'); }).dequeue('msg'); return 'Please drop image file...'; }); }; };
更新了 PHP:
<?php if (isset($_POST['file'])) { // do php stuff // call `json_encode` on `file` object $file = json_encode($_POST['file']); // return `file` as `json` string echo $file; }
通过实现此修改后的代码,您可以使用 AJAX、PHP 和jQuery。
以上是如何使用 AJAX、PHP 和 jQuery 高效上传多个图像?的详细内容。更多信息请关注PHP中文网其他相关文章!

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

热门话题

本文讨论了在浏览器中优化JavaScript性能的策略,重点是减少执行时间并最大程度地减少对页面负载速度的影响。

本文讨论了使用浏览器开发人员工具的有效JavaScript调试,专注于设置断点,使用控制台和分析性能。

Python和JavaScript开发者的薪资没有绝对的高低,具体取决于技能和行业需求。1.Python在数据科学和机器学习领域可能薪资更高。2.JavaScript在前端和全栈开发中需求大,薪资也可观。3.影响因素包括经验、地理位置、公司规模和特定技能。

本文说明了如何使用源地图通过将其映射回原始代码来调试JAVASCRIPT。它讨论了启用源地图,设置断点以及使用Chrome DevTools和WebPack之类的工具。

本教程将介绍如何使用 Chart.js 创建饼图、环形图和气泡图。此前,我们已学习了 Chart.js 的四种图表类型:折线图和条形图(教程二),以及雷达图和极地区域图(教程三)。 创建饼图和环形图 饼图和环形图非常适合展示某个整体被划分为不同部分的比例。例如,可以使用饼图展示野生动物园中雄狮、雌狮和幼狮的百分比,或不同候选人在选举中获得的投票百分比。 饼图仅适用于比较单个参数或数据集。需要注意的是,饼图无法绘制值为零的实体,因为饼图中扇形的角度取决于数据点的数值大小。这意味着任何占比为零的实体

深入探讨console.log输出差异的根源本文将分析一段代码中console.log函数输出结果的差异,并解释其背后的原因。�...
