91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

nodejs如何實現本地上傳圖片并預覽功能

發布時間:2021-04-23 11:23:08 來源:億速云 閱讀:536 作者:小新 欄目:web開發

小編給大家分享一下nodejs如何實現本地上傳圖片并預覽功能,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

js有什么特點

1、js屬于一種解釋性腳本語言;2、在絕大多數瀏覽器的支持下,js可以在多種平臺下運行,擁有著跨平臺特性;3、js屬于一種弱類型腳本語言,對使用的數據類型未做出嚴格的要求,能夠進行類型轉換,簡單又容易上手;4、js語言安全性高,只能通過瀏覽器實現信息瀏覽或動態交互,從而有效地防止數據的丟失;5、基于對象的腳本語言,js不僅可以創建對象,也能使用現有的對象。

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什么的,并木有列出來

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

nodejs如何實現本地上傳圖片并預覽功能

以上是“nodejs如何實現本地上傳圖片并預覽功能”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

博罗县| 印江| 寿光市| 綦江县| 诏安县| 彩票| 武陟县| 攀枝花市| 新蔡县| 贺州市| 深圳市| 罗江县| 甘洛县| 温泉县| 财经| 镇巴县| 丰顺县| 井研县| 利津县| 陈巴尔虎旗| 香格里拉县| 鸡东县| 胶南市| 马山县| 澄江县| 沾益县| 大荔县| 拉萨市| 海南省| 双流县| 清丰县| 周口市| 偏关县| 永和县| 武山县| 故城县| 临洮县| 桃江县| 阳谷县| 莆田市| 甘谷县|