微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

nodejs 图片预览和上传的示例代码

本文介绍了nodejs 图片预览和上传的示例代码分享给大家,具体如下:

效果如下:

前言

一般在上传图片之前需要暂存在本地预览一下。

前端图片预览用的是 FileReader的readAsDataURL方法

nodejs 图片上传用的是中间件 Multer

本地图片预览

FileReader对象允许web应用程序异步读取存储在用户计算机上的文件(或原始数据缓冲区)的内容,使用文件或Blob对象来指定要读取的文件或数据。

readAsDataURL方法用于读取指定的Blob或文件内容。当读取操作完成后,readyState就完成了,并且触发了loadend。在那个时候,result属性将数据作为一个URL表示文件的数据,作为base64编码的字符串。

单个图片预览

html 部分

rush:xhtml;"> Image preview...

javascript 部分

rush:js;"> function previewFile() { var preview = document.querySelector('img'); var file = document.querySelector('input[type=file]').files[0]; var reader = new FileReader();

reader.addEventListener("load",function () {
preview.src = reader.result;
},false);

if (file) {
reader.readAsDataURL(file);
}
}

多张图片预览

html 部分

rush:xhtml;">

javascript 部分

rush:js;"> function previewFiles() {

var preview = document.querySelector('#preview');
var files = document.querySelector('input[type=file]').files;

function readAndPreview(file) {

// 支持图片类型(可自定义
if ( /.(jpe?g|png|gif)$/i.test(file.name) ) {
var reader = new FileReader();

reader.addEventListener("load",function () {
var image = new Image();
image.height = 100;
image.title = file.name;
image.src = this.result;
preview.appendChild( image );
},false);

reader.readAsDataURL(file);
}

}
//files 就是input选中的文件,你也可以对上传图片个数进行限制 (files.length)
if (files) {
[].forEach.call(files,readAndPreview);
}

}

项目中运用

前端部分

html

rush:xhtml;">

javascript

js 方法部分拆开了下,放在一个代码块中有点长 (阅读时请查看上下文)

rush:js;"> $(function(){ var upload={ txtUploadFile:$('#txtUploadFile'),//上传单个文件 txtUploadFileList:$('#txtUploadFileList'),//上传多个文件 btnSend:$('#btnSend'),//上传文件 preview:$('#preview'),//图片预览盒子 //预览图片加载 previewImgLoad:function(fileList){ for(var i=0;i
rush:js;"> /* 上传单个文件 这里是input改变时后直接上传(用于修改用户头像) 你也可以在点击上传按钮后再上传,下面的多图上传会给出案例 */ upload.txtUploadFile.change(function(){ var formData = new FormData(); formData.append('avatar',upload.txtUploadFile[0].files[0]); $.ajax({ url: '/upload/file',type: 'post',cache: false,data: formData,processData: false,contentType: false,success:function(res){ console.log('upload success'); },error:function(){ console.log('upload faild'); } }); });
rush:js;"> //加载预览图片 upload.txtUploadFileList.change(function(){ var fileList=this.files; upload.previewImgLoad(fileList); });
rush:js;"> //上传多张图片 upload.btnSend.click(function(){ var files = upload.txtUploadFileList.prop('files'); if(files.length==0){ //没有选择文件直接返回 return; } var formData=new FormData(); for(var i=0;i图片已经上传成功了.你可根据返回结果处理其他的业务逻辑 if(res.status==1){ // todo something } },error:function(){ console.log('upload faild'); } });
});

nodejs 部分

nodejs 用的是Multer中间件,这个中间件主要用于上传文件

安装Multer

rush:bash;"> npm install --save multer

Multer在nodejs中使用

rush:js;"> var express = require('express'); var multer = require('multer'); var app = express();

//磁盘存储引擎(说白了就是指定上传文件存储到哪,当然你也可以对文件重命名等等)
var storage=multer.diskStorage({
destination: function (req,file,cb) {
//我这里是存储在public下的uploads目录
cb(null,'public/uploads/')
},filename: function (req,cb) {
cb(null,file.fieldname + '-' + Date.Now()+"_" + file.originalname)
}
});

单个图片上传

rush:js;"> //如果图片上传成功会返回图片的存储路径 app.post('/upload/file',upload.single('avatar'),function(req,res) { if (!req.file) { console.log("no file received"); return res.send({ status: 0,filePath:'' }); } else { console.log('file received'); res.send({ status:1,filePath: '/uploads/' + path.basename(req.file.path) }); } });

多张图片上传

rush:js;"> // 如果图片上传成功会返回图片的存储路径(数组) app.post('/upload/filesList',upload.array('photos',9),res) { if (req.files==undefined) { console.log("no files received"); return res.send({ status: 0,filePath:'' }); } else { var filesPathArr=[]; for(var i=0;i

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程之家。

原文地址:https://www.jb51.cc/nodejs/35991.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐