欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時間:2017年06月28日 09:17:57   作者:a67  
本篇文章主要介紹了nodejs實現(xiàn)本地上傳圖片并預(yù)覽功能(express4.0+) ,具有一定的參考價值,有興趣的可以了解一下

Express為:4.13.1  multyparty: 4.1.2

代碼主要實現(xiàn)本地圖片上傳到nodejs服務(wù)器的文件下,通過取圖片路徑進(jìn)行圖片預(yù)覽

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

相關(guān)查看文檔:

通過Ajax方式上傳文件,使用FormData進(jìn)行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事件,即當(dāng)選完圖片時就發(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對象,并配置上傳目標(biāo)路徑
 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');
  }
 });
}

部分說明:

文件上傳至服務(wù)器后 路徑path變?yōu)椋簆ublic\files\images\W-jy9YsxsPjNpQHslzGvdXBk.jpg

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

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

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

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

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Node.js、Socket.IO和GPT-4構(gòu)建AI聊天機(jī)器人的項目實踐

    Node.js、Socket.IO和GPT-4構(gòu)建AI聊天機(jī)器人的項目實踐

    本文主要介紹了Node.js、Socket.IO和GPT-4構(gòu)建AI聊天機(jī)器人的項目實踐,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-05-05
  • Nodejs下DNS緩存問題淺析

    Nodejs下DNS緩存問題淺析

    本文給大家一起探討nodejs下dns的緩存問題,本文給大家介紹的非常詳細(xì),感興趣的朋友一起看看吧
    2016-11-11
  • nvm版本導(dǎo)致npm?install報錯Unexpected?token?'.'的解決辦法

    nvm版本導(dǎo)致npm?install報錯Unexpected?token?'.'的解決辦法

    最近做項目遇到npm install 的問題,下面這篇文章主要給大家介紹了關(guān)于nvm版本導(dǎo)致npm?install報錯Unexpected?token?'.'的解決辦法,文中通過圖文介紹的非常詳細(xì),需要的朋友可以參考下
    2022-07-07
  • Node.js 8 中的重要新特性

    Node.js 8 中的重要新特性

    這篇文章主要介紹了Node.js 8 中的重要新特性的相關(guān)資料,需要的朋友可以參考下
    2017-06-06
  • Node.js實現(xiàn)兼容IE789的文件上傳進(jìn)度條

    Node.js實現(xiàn)兼容IE789的文件上傳進(jìn)度條

    這篇文章給大家介紹了如何實現(xiàn)兼容IE789的文件上傳進(jìn)度條,如果你的工作用過上傳圖片或上傳大文件啥的,一般在IE低版本瀏覽器里,會切換到用flash解決,可是有些人肯定不會為了老舊IE的進(jìn)度條而去學(xué)flash,那么下面來一起看看吧。
    2016-09-09
  • Node.js利用斷言模塊assert進(jìn)行單元測試的方法

    Node.js利用斷言模塊assert進(jìn)行單元測試的方法

    最近在用Node寫一個實時聊天小應(yīng)用,其中就用到了單元測試,所以死下面這篇文章主要給大家介紹了關(guān)于Node.js利用斷言模塊assert進(jìn)行單元測試的方法,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考借鑒,下面來一起看看吧。
    2017-09-09
  • Nodejs使用exceljs實現(xiàn)excel導(dǎo)入導(dǎo)出

    Nodejs使用exceljs實現(xiàn)excel導(dǎo)入導(dǎo)出

    在日常開發(fā)中,我們常需在后臺管理系統(tǒng)中實現(xiàn)數(shù)據(jù)的導(dǎo)入與導(dǎo)出功能,以便與?Excel?文件進(jìn)行交互,本文將使用使用exceljs實現(xiàn)excel導(dǎo)入導(dǎo)出功能,需要的可以參考下
    2024-03-03
  • 使用GruntJS構(gòu)建Web程序之Tasks(任務(wù))篇

    使用GruntJS構(gòu)建Web程序之Tasks(任務(wù))篇

    任務(wù)(Tasks)是grunt的核心概念,你所做的很多工作比如資源合并(concat)、壓縮(uglify)都是在配置任務(wù)。 每次grunt運行的時候,你指定的一個或多個任務(wù)也在運行,如果你沒有指定任務(wù),那么一個默認(rèn)名為“default”的任務(wù)將自動運行。
    2014-06-06
  • 云服務(wù)器部署Node.js項目的方法步驟(小白系列)

    云服務(wù)器部署Node.js項目的方法步驟(小白系列)

    這篇文章主要介紹了云服務(wù)器部署Node.js項目的方法步驟,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-03-03
  • 詳解Node.js中的模塊化方法

    詳解Node.js中的模塊化方法

    這篇文章主要為大家介紹了Node.js的模塊化,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-01-01

最新評論