国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

詳解nodejs實現本地上傳圖片并預覽功能(express4.0+)

2019-11-19 16:14:05
字體:
來源:轉載
供稿:網友

Express為:4.13.1  multyparty: 4.1.2

代碼主要實現本地圖片上傳到nodejs服務器的文件下,通過取圖片路徑進行圖片預覽

寫在前面:計劃實現圖片上傳預覽功能,但是本地圖片上傳所獲得路徑為 C:/fakepath/"+文件名的形式,得不到文件真實路徑,所以無法直接預覽,于是采用將圖片上傳至服務器,傳回服務器路徑,實現預覽。前端采用通過ajax方式上傳文件,使用FormData進行ajax請求  ,nodejs端采用multiparty模塊

相關查看文檔:

通過Ajax方式上傳文件,使用FormData進行Ajax請求

node-multiparty github

FormData - Web APIs | MDN

部分代碼:

<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事件,即當選完圖片時就發送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變為:public/files/images/W-jy9YsxsPjNpQHslzGvdXBk.jpg

由于在app.js中設置過public為默認路徑,所以整理地址時需要去掉public,并且把‘/'變成‘/'

app.use(express.static(path.join(__dirname, 'public')));

 最后效果大概是這樣的,html部分不一樣~我的是jade模板,還有css什么的,并木有列出來

點擊空白處,上傳圖片,接下來的功能就是點擊上傳把地址放到數據庫里~(這個功能還木有做呢)

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 临高县| 怀宁县| 牙克石市| 兴安县| 加查县| 洛阳市| 清流县| 子洲县| 那曲县| 武汉市| 库伦旗| 蓝田县| 神农架林区| 涞水县| 宜春市| 新化县| 甘肃省| 宁城县| 周宁县| 正镶白旗| 鞍山市| 三明市| 瑞安市| 延津县| 凌云县| 同江市| 岳普湖县| 合阳县| 鹤岗市| 陆河县| 大兴区| 澳门| 亳州市| 朝阳市| 鸡东县| 荔波县| 广昌县| 西青区| 盱眙县| 凤凰县| 石阡县|