<form id="form" enctype="multipart/form-data">
  <input type="text" name="name" id="name" value="" />

   //单图上传的时候name值也必须为img[]  不然后台接收数据的时候不是数组 还需要if处理    否则后台for循环就会报错
  <input type="file" name="img[]" id="img" value="" multiple="multiple"/>        <button type="button">提交</button> </form>

 $("button").click(function(){     var Data = new FormData($("#form")[0]);     $.ajax({         type:"post",        url:"/admin/updata",         data:Data,         contentType:false,         //取消帮我们格式化数据,是什么就是什么         processData:false,         dataType:'json',         success:function(data){    

   }     }) })
var multipart = require('connect-multiparty');
var multipartMiddleware = multipart();

router.post('/updata',multipartMiddleware, function(req, res, next) {
    res.clearCookie('data_img');
    console.log(req.body, req.files);
    var id=req.body.id
    var img=req.files.img
    var list_img=[]
    var k=0
    img.forEach(function(item){
        var filepath=item.path
        var filename=item.originalFilename
        if(filename){
            fs.readFile(filepath,function(err,data){
                var t = (new Date()).getTime();
                var type=item.type.split("/")[1]
                var newname=t+'.'+type
                var m='/upload1/' + newname
                var newpath = path.join(__dirname, '../','public/upload1/'+newname);
                fs.writeFile(newpath,data,function(err){
                    if(id){
                        Banner.update({
                            _id: id
                        }, {img:m}, function(err,data) {
                            console.log(data)
                            if(err) {
                                var data = {code: 0,messege: '数据更新失败'}
                            } else {
                                list_img.push({img:m})
                                var data = {code: 1,messege: '数据更新成功',data:list_img}
                            }
                            res.send(data);
                        })
                    }else{
                        var banner = new Banner({
                            img: m
                        })
                        banner.save(function(err,retult){
//                            console.log(retult)
                            list_img.push(retult)
                            k++
                            if(k==img.length){
                                var data = {code: 1,messege: '上传成功',data:list_img}
                                res.send(data);
                            }
                        })
                    }
                })
            })
        }
    })
})
	<form  enctype="multipart/form-data">
		<h2 class="title">banner上传</h2>
		<ul class="row">
			<% banner.forEach(function(item){ %>
				<li class="col-sm-3">
					<div class="box">
						<img src="<%= item.img%>">
						<p class="glyphicon glyphicon-trash bg-danger delete"></p>
						<input type="file" name="img[]" id="<%= item._id%>" value=""/>
					</div>
				</li>
			<% }); %>
			<li class="col-sm-3">
				<div class="box">
					<img src="/images/timg.jpg">
					<input type="file" name="img[]" value=""  multiple="multiple"/>
				</div>
			</li>
		</ul>
	</form>

		$("input").change(function(){
			var id=$(this).attr("id")
			console.log(id)
			var formData = new FormData();
			for (var i=0;i<$(this)[0].files.length;i++) {
		        formData.append("img[]",$(this)[0].files[i]);//循环遍历把文件对象插到formData对象上
			}
			if(id){
				formData.append("id", id)
				var obj=$(this)[0].files[0]
				var img=window.URL.createObjectURL(obj);
				$(this).siblings("img").attr("src",img)
			}

			$.ajax({
				type:"post",
				url:"/admin/updata11",
				data:formData,
				dataType:'json',
	            contentType: false,//使用multer配合ajax时无需配置multipart/form-data,multer将自动配置,手动配置将报错,boundary not found
	            processData: false,
				success:function(data){
					console.log(data)
					alert(data.messege)
					var html=''
					var data=data.data
					if(!id){
						data.forEach(function(item){
							html+=	`<li class="col-sm-3">
										<div class="box">
											<img src="${item.img}">
											<p class="glyphicon glyphicon-trash bg-danger delete"></p>
											<input type="file" name="img[]" id="${item._id}%>" value=""/>
										</div>
									</li>`
						})
						$("form ul").prepend(html)
					}
				}
			})
		})

  

node多图或者单图上传的更多相关文章

  1. Laravel5多图上传和Laravel5单图上传的功能实现

    Laravel5文件上传默认只能上传一张图片,但是有的时候我们需要一次性上传多图就不行了,我在网上看了很多关于laravel5图片上传的文章,很多都只是介绍laravel5单图上传,多图片上传介绍少之 ...

  2. js formData图片上传(单图上传、多图上传)后台java

    单图上传 <div class="imgUp">     <label>头像单图</label>     <input type=&quo ...

  3. mui开发app之多图压缩与上传(仿qq空间说说发表)

    欲实现效果图 提出需求点: 用户可自由添加删除替换多张图片,并且显示相应缩略图,限制为8张 用户可选择压缩图或直接上传原图功能 返回提醒用户会丢失填写的信息 下面一个个实现上述需求,从简单到复杂: 需 ...

  4. UEditor单图上传跨域问题解决方案

    UEditor UEditor是百度团队提供的富文本编辑器 git地址为:https://github.com/fex-team/ueditor 在最近的项目中使用了该插件作为项目的富文本编辑器 由于 ...

  5. 记录一次node中台转发表单上传文件到后台过程

    首发掘金 记录一次node中台转发表单上传文件到后台过程 本篇跟掘金为同一个作者leung   公司几个项目都是三层架构模式即前台,中台(中间层),后台.前台微信端公众号使用vue框架,后台管理前端使 ...

  6. UEditor实现前后端分离时单图上传

    首先,需要下载部署ueditor相关代码,可以参考一篇简单的博客,这里不再赘述: 环境搭建好后,我们先简单使用一下,启动http://web.yucong.com:8080/ueditor/index ...

  7. ajax 异步插入图片到数据库(单图上传)

    其实也没啥  如图: 点击按钮选择图片,选择完成后 无需点击确定 ,自动上传到服务器指定文件夹 然后插入到数据库中. 下面来看看这要代码 index.php <!DOCTYPE HTML> ...

  8. 单图上传预览(uploadpreview )

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  9. thinkphp 单图上传组建成数组然后追加到一个字段

    //上传的数组字段 $note1 = input('note1'); $note2 = input('note2'); $note3 = input('note3'); $note4 = input( ...

随机推荐

  1. WinForm实现Rabbitmq官网6个案例-Publishe/Subscribe

    代码: namespace RabbitMQDemo { public partial class PublishSubscribe : Form { private string exchangeN ...

  2. Linux 下MySQL的基本操作

    1.连接MySQL 连接到本机的MySQL 键入命令mysql -u root -p 回车提示你输入密码. Ps:用户名前可以有空格也可以没有空格,但是密码前必须没有空格 MySQL的提示符是: my ...

  3. redis 序列化get、set获取不到原因记录

    最近项目里面出现了个bug,把数据从数据库中读取后又存取到redis里面,之后再读取.奇怪的是,有一个 字段读取不到. public class Circle { private String id; ...

  4. 微信小程序 - 弹出键盘遮挡住输入框

    在开发微信小程序的时候遇到,输入用户名或者手机号以及地址,手机键盘调起来,会把输入框遮挡. 如图: 以上两张图是自己工作中遇到的,此处不要着急,一个属性帮你搞定. cursor-spacing:指定光 ...

  5. notepad 操作总结

    1.竖向选择 先把鼠标光标放在起始位置,然后同时按 Alt+Ctrl 或Alt+shift键,然后移动鼠标选取内容. Word中只能用Alt+Shift .

  6. INFORMATICA 开发规范

    目    录 Informatica开发规范.... 1 目    录.... 2 1        编写目的.... 4 2        ETL研发责任人界定.... 4 3        ETL ...

  7. linux用户的增加与删除

    sudo useradd xxx 仅仅是添加用户, 不会在home目录添加帐号很简单 Ubuntu中提供了两种方式 图形界面 增加 和 Windows 一样 ,还有一种就是 Linux传统的 增加方法 ...

  8. CAShapeLayer的使用[2]

    CAShapeLayer的使用[2] CAShapeLayer支持的动画类型有如下这些. ------------------------------------------------------- ...

  9. 问题记录-Get data from file(fonts/arial.ttf) failed, error code is 32

    time:2015/04/19 1. 描述:运行cocos的cpp-test例子,结果修改了代码之后提示错误:Get data from file(fonts/arial.ttf) failed, e ...

  10. EF学习之CodeFirst(二)--数据迁移

    使用CodeFirst时,如果Model发生改变的话,例如我们给User类里面新加个Sex属性,运行时会出现如下错误: 这时我们需要使用数据迁移来将model的改变同步更新到数据库中. 1.启用数据迁 ...