热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

html多图片上传预览ajax提交附件上传js获取uuid

样式a{text-decoration:none;}.div_enclosure{padding:5px;}.div_enclosurep{font-size:13px;line-

样式

a{
text-decoration
: none;
}
.div_enclosure
{
padding
: 5px;
}
.div_enclosure p
{
font-size
: 13px;
line-height
: 15px !important;
margin-bottom
: 5px;
}
.enclosures .div_img_preview
{
width
: 60px;
height
: 60px;
margin-top
: 10px;
margin-right
: 10px;
float
: left;
position
: relative;
}
.enclosures .div_img_preview img
{
width
: 100%;
height
: 100%;
}
/*样式1*/
.a-upload
{
background-image
: url('/content/img/ic_add_image.png');
background-size
: cover;
cursor
: pointer;
overflow
: hidden;
display
: inline-block;
*display
: inline;
*zoom
: 1
}
.a-upload input
{
position
: absolute;
font-size
: 100px;
right
: 0;
top
: 0;
opacity
: 0;
filter
: alpha(opacity=0);
cursor
: pointer
}
.span_close
{
display
: block;
width
: 20px;
height
: 20px;
background-image
: url('/content/img/ic_delete_menu.png');
background-size
: cover;
position
: absolute;
top
: -10px;
right
: -10px;
}

style.css

js

//生成uuid()
function getUuid() {
var s = [];
var hexDigits = "0123456789abcdef";
for (var i = 0; i <36; i++) {
s[i]
= hexDigits.substr(Math.floor(Math.random() * 0x10), 1);
}
s[
14] = "4"; // bits 12-15 of the time_hi_and_version field to 0010
s[19] = hexDigits.substr((s[19] & 0x3) | 0x8, 1); // bits 6-7 of the clock_seq_hi_and_reserved to 01
s[8] = s[13] = s[18] = s[23] = "-";

var uuid = s.join("");
return uuid;
}

获取uuid

function AddUpload(divId) {
var div = $('

')
var inputFile = $('');
$(inputFile).on(
"change", function (e) {
var src, url = window.URL || window.webkitURL || window.mozURL, files = e.target.files;
//预览
for (var i = 0, len = files.length; i i) {
var file = files[i];
var filetype = file.type;
var size = file.size;
if (size > 10 * 1024 * 1024) {
alert(
"请上传小于10M的图片");
}
else {
if (url) {
src
= url.createObjectURL(file);
}
else {
src
= e.target.result;
}
var uuid = getUuid();
curFiles.push(
{
uuid: uuid,
file: file
});
var previewDiv = $('
');
var closeBtn = $('');
$(closeBtn).click(
function () {
var thisdiv = $(this).parent();
var thisuuid = $(thisdiv).attr("uuid");
curFiles.removeKey(
"uuid", thisuuid);
$(thisdiv).remove();
});
$(previewDiv).append(closeBtn);
$(
this).parent().before(previewDiv);
}
}
if (files.length > 0) {
//隐藏当前上传按钮
$(this).parent().hide();
//添加新上传按钮
AddUpload(divId);
}
});
$(div).append(inputFile);
$(
"#" + divId).append(div);
}

index.js

调用

<div class="div_enclosure">
<p>附件:p>
<div class="enclosures" id="divEnclosures">
div>
div>
<script>
var curFiles = [];//用于保存上传后的图片
//添加上传按钮
AddUpload("divEnclosures");
function submit() {
var form = new FormData($("#createForm")[0]);
for (var [a, b] of form.entries()) {
//如果value是file类型的
if (b instanceof File) {
if (b.name != "") {
//先将表单中原有的fileList对象中的文件删除
form.delete(a);
for (var i = 0; i < curFiles.length; i++) {
//然后再将curFiles的文件追加到表单中
form.append(a, curFiles[i].file);
}
//var f1 = new File([],"");
//form.append(a,f1);
}
}
}
$.ajax({
url: BaseUrl
+ 'pm/message/saveMeaasge',
type:
'post',
cache:
false,
data: form,
processData:
false,
contentType:
false,
success:
function (data) {
location.href
= returl;
}
});
}
script>

demo.html

附件

注:以上代码属个人整理,用于交流学习。(QQ/微信:742010299 昵称:同心同德)



推荐阅读
  • 基于layUI的图片上传前预览功能的2种实现方式
    本文介绍了基于layUI的图片上传前预览功能的两种实现方式:一种是使用blob+FileReader,另一种是使用layUI自带的参数。通过选择文件后点击文件名,在页面中间弹窗内预览图片。其中,layUI自带的参数实现了图片预览功能。该功能依赖于layUI的上传模块,并使用了blob和FileReader来读取本地文件并获取图像的base64编码。点击文件名时会执行See()函数。摘要长度为169字。 ... [详细]
  • [译]技术公司十年经验的职场生涯回顾
    本文是一位在技术公司工作十年的职场人士对自己职业生涯的总结回顾。她的职业规划与众不同,令人深思又有趣。其中涉及到的内容有机器学习、创新创业以及引用了女性主义者在TED演讲中的部分讲义。文章表达了对职业生涯的愿望和希望,认为人类有能力不断改善自己。 ... [详细]
  • 本文讨论了在手机移动端如何使用HTML5和JavaScript实现视频上传并压缩视频质量,或者降低手机摄像头拍摄质量的问题。作者指出HTML5和JavaScript无法直接压缩视频,只能通过将视频传送到服务器端由后端进行压缩。对于控制相机拍摄质量,只有使用JAVA编写Android客户端才能实现压缩。此外,作者还解释了在交作业时使用zip格式压缩包导致CSS文件和图片音乐丢失的原因,并提供了解决方法。最后,作者还介绍了一个用于处理图片的类,可以实现图片剪裁处理和生成缩略图的功能。 ... [详细]
  • 校园表白墙微信小程序,校园小情书、告白墙、论坛,大学表白墙搭建教程
    小程序的名字必须和你微信注册的名称一模一样在后台注册好小程序。mp.wx-union.cn后台域名https。mp.wx-union.cn ... [详细]
  • 本文介绍了lua语言中闭包的特性及其在模式匹配、日期处理、编译和模块化等方面的应用。lua中的闭包是严格遵循词法定界的第一类值,函数可以作为变量自由传递,也可以作为参数传递给其他函数。这些特性使得lua语言具有极大的灵活性,为程序开发带来了便利。 ... [详细]
  • 本文介绍了在Python3中如何使用选择文件对话框的格式打开和保存图片的方法。通过使用tkinter库中的filedialog模块的asksaveasfilename和askopenfilename函数,可以方便地选择要打开或保存的图片文件,并进行相关操作。具体的代码示例和操作步骤也被提供。 ... [详细]
  • PHP图片截取方法及应用实例
    本文介绍了使用PHP动态切割JPEG图片的方法,并提供了应用实例,包括截取视频图、提取文章内容中的图片地址、裁切图片等问题。详细介绍了相关的PHP函数和参数的使用,以及图片切割的具体步骤。同时,还提供了一些注意事项和优化建议。通过本文的学习,读者可以掌握PHP图片截取的技巧,实现自己的需求。 ... [详细]
  • Java序列化对象传给PHP的方法及原理解析
    本文介绍了Java序列化对象传给PHP的方法及原理,包括Java对象传递的方式、序列化的方式、PHP中的序列化用法介绍、Java是否能反序列化PHP的数据、Java序列化的原理以及解决Java序列化中的问题。同时还解释了序列化的概念和作用,以及代码执行序列化所需要的权限。最后指出,序列化会将对象实例的所有字段都进行序列化,使得数据能够被表示为实例的序列化数据,但只有能够解释该格式的代码才能够确定数据的内容。 ... [详细]
  • 也就是|小窗_卷积的特征提取与参数计算
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了卷积的特征提取与参数计算相关的知识,希望对你有一定的参考价值。Dense和Conv2D根本区别在于,Den ... [详细]
  • C++中的三角函数计算及其应用
    本文介绍了C++中的三角函数的计算方法和应用,包括计算余弦、正弦、正切值以及反三角函数求对应的弧度制角度的示例代码。代码中使用了C++的数学库和命名空间,通过赋值和输出语句实现了三角函数的计算和结果显示。通过学习本文,读者可以了解到C++中三角函数的基本用法和应用场景。 ... [详细]
  • 本文讨论了编写可保护的代码的重要性,包括提高代码的可读性、可调试性和直观性。同时介绍了优化代码的方法,如代码格式化、解释函数和提炼函数等。还提到了一些常见的坏代码味道,如不规范的命名、重复代码、过长的函数和参数列表等。最后,介绍了如何处理数据泥团和进行函数重构,以提高代码质量和可维护性。 ... [详细]
  • 本文介绍了如何使用JSONObiect和Gson相关方法实现json数据与kotlin对象的相互转换。首先解释了JSON的概念和数据格式,然后详细介绍了相关API,包括JSONObject和Gson的使用方法。接着讲解了如何将json格式的字符串转换为kotlin对象或List,以及如何将kotlin对象转换为json字符串。最后提到了使用Map封装json对象的特殊情况。文章还对JSON和XML进行了比较,指出了JSON的优势和缺点。 ... [详细]
  • 图像因存在错误而无法显示 ... [详细]
  • 在tp5项目中引入ueditor编辑器并实例化后插入图片出现目录创建失败问题在查看网络上各种解决方案之后总结如下:根据官网提示主要是因为图片保存的路径无权限导致,官方文档链接:ht ... [详细]
  • fileuploadJS@sectionscripts{<scriptsrc~Contentjsfileuploadvendorjquery.ui.widget.js ... [详细]
author-avatar
余方兰很快乐
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有