詳解nodejs實現(xiàn)本地上傳圖片并預覽功能(express4.0+)
Express為:4.13.1 multyparty: 4.1.2
代碼主要實現(xiàn)本地圖片上傳到nodejs服務器的文件下,通過取圖片路徑進行圖片預覽
寫在前面:計劃實現(xiàn)圖片上傳預覽功能,但是本地圖片上傳所獲得路徑為 C:\fakepath\"+文件名的形式,得不到文件真實路徑,所以無法直接預覽,于是采用將圖片上傳至服務器,傳回服務器路徑,實現(xiàn)預覽。前端采用通過ajax方式上傳文件,使用FormData進行ajax請求 ,nodejs端采用multiparty模塊
相關(guān)查看文檔:
通過Ajax方式上傳文件,使用FormData進行Ajax請求
部分代碼:
<form name='picForm' action = "javascript:;"method="post" encype = "multipart/form-data" > <input type="file" id="test" id="j_imgfile"> </form> <div> <img src="" id="j_imgPic"> </div>
js中采用change事件,即當選完圖片時就發(fā)送ajax請求
$('#j_imgfile').on('change',function(){
// 判斷上傳文件類型
var objFile = $('#j_imgfile').val();
var objType = objFile.substring(objFile.lastIndexOf(".")).toLowerCase();
var formData = new FormData(document.forms.namedItem("picForm"));
console.log(objType);
if(!(objType == '.jpg'||objType == '.png'))
{
alert("請上傳jpg、png類型圖片");
return false;
}else{
$.ajax({
type : 'post',
url : '/uploadUserImgPre',
data: formData ,
processData:false,
async:false,
cache: false,
contentType: false,
success:function(re){
re.imgSrc = re.imgSrc.replace('public','');
re.imgSrc = re.imgSrc.replace(/\\/g,'\/');
$('#j_imgPic').attr('src',re.imgSrc);
},
error:function(re){
console.log(re);
}
});
}
});
nodejs app.js里代碼
app.post('/uploadUserImgPre',routes.users.uploadUserImgPre);
routes/users.js 里代碼
exports.uploadUserImgPre = function(req, res, next) {
//生成multiparty對象,并配置上傳目標路徑
var form = new multiparty.Form({uploadDir: './public/files/images'});
form.parse(req, function(err, fields, files) {
var filesTmp = JSON.stringify(files);
if(err){
console.log('parse error: ' + err);
} else {
testJson = eval("(" + filesTmp+ ")");
console.log(testJson.fileField[0].path);
res.json({imgSrc:testJson.fileField[0].path})
console.log('rename ok');
}
});
}
部分說明:
文件上傳至服務器后 路徑path變?yōu)椋簆ublic\files\images\W-jy9YsxsPjNpQHslzGvdXBk.jpg
由于在app.js中設置過public為默認路徑,所以整理地址時需要去掉public,并且把‘\'變成‘/'
app.use(express.static(path.join(__dirname, 'public')));
最后效果大概是這樣的,html部分不一樣~我的是jade模板,還有css什么的,并木有列出來
點擊空白處,上傳圖片,接下來的功能就是點擊上傳把地址放到數(shù)據(jù)庫里~(這個功能還木有做呢)

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
- node+axios實現(xiàn)服務端文件上傳示例
- 利用node+koa+axios實現(xiàn)圖片上傳和回顯功能
- 詳解Vue+axios+Node+express實現(xiàn)文件上傳(用戶頭像上傳)
- nodejs+express實現(xiàn)文件上傳下載管理網(wǎng)站
- nodejs基于express實現(xiàn)文件上傳的方法
- Nodejs+express+html5 實現(xiàn)拖拽上傳
- 基于nodejs+express(4.x+)實現(xiàn)文件上傳功能
- 使用express+multer實現(xiàn)node中的圖片上傳功能
- 使用nodejs+express實現(xiàn)簡單的文件上傳功能
- Ajax異步文件上傳與NodeJS express服務端處理
- Nodejs進階:基于express+multer的文件上傳實例
- NodeJS實現(xiàn)圖片上傳代碼(Express)
- node+express+axios實現(xiàn)單文件上傳功能
相關(guān)文章
Node.js、Socket.IO和GPT-4構(gòu)建AI聊天機器人的項目實踐
本文主要介紹了Node.js、Socket.IO和GPT-4構(gòu)建AI聊天機器人的項目實踐,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2023-05-05
nvm版本導致npm?install報錯Unexpected?token?'.'的解決辦法
最近做項目遇到npm install 的問題,下面這篇文章主要給大家介紹了關(guān)于nvm版本導致npm?install報錯Unexpected?token?'.'的解決辦法,文中通過圖文介紹的非常詳細,需要的朋友可以參考下2022-07-07
Node.js實現(xiàn)兼容IE789的文件上傳進度條
這篇文章給大家介紹了如何實現(xiàn)兼容IE789的文件上傳進度條,如果你的工作用過上傳圖片或上傳大文件啥的,一般在IE低版本瀏覽器里,會切換到用flash解決,可是有些人肯定不會為了老舊IE的進度條而去學flash,那么下面來一起看看吧。2016-09-09
Nodejs使用exceljs實現(xiàn)excel導入導出
在日常開發(fā)中,我們常需在后臺管理系統(tǒng)中實現(xiàn)數(shù)據(jù)的導入與導出功能,以便與?Excel?文件進行交互,本文將使用使用exceljs實現(xiàn)excel導入導出功能,需要的可以參考下2024-03-03
使用GruntJS構(gòu)建Web程序之Tasks(任務)篇
任務(Tasks)是grunt的核心概念,你所做的很多工作比如資源合并(concat)、壓縮(uglify)都是在配置任務。 每次grunt運行的時候,你指定的一個或多個任務也在運行,如果你沒有指定任務,那么一個默認名為“default”的任務將自動運行。2014-06-06

