node+vue實(shí)現(xiàn)文件上傳功能
本文實(shí)例為大家分享了node+vue實(shí)現(xiàn)文件上傳的具體代碼,供大家參考,具體內(nèi)容如下
*后端*
const express = require('express');
const Router = express.Router();
const multer = require('multer');
const fs = require('fs');
const pathLib = require('path');
const videoModel = require('../../models/my_yx_app/video');
//設(shè)置 視頻文件存放位置
const uploadVido = multer({
dest:'uploads_yx_app/video/'
});
//上傳視頻
Router.post('/uploadVideo',uploadVido.single('file'),(req,res)=>{
if (req.file) {
let file = req.file;
let newName = file.path+pathLib.parse(file.originalname).ext; //修改path
fs.rename(file.path,newName,(err)=>{ //修改path
if (err) {
return res.status(200).json({
code:0,
msg:'服務(wù)器繁忙!'
})
}else {
return res.status(200).json({
code:1,
msg:'上傳完成',
title:pathLib.parse(file.originalname).name,
videoUrl:'http://127.0.0.1:3001/uploads_yx_app/video/'+file.filename+pathLib.parse(file.originalname).ext
})
}
})
}else {
return res.status(200).json({
code:0,
msg:'服務(wù)器繁忙!'
})
}
});
*前端*
<div class="from-contral" style="position: relative">
<!--此處name 與 uploadVido.single('file') 相同-->
<input type="file" name="file" @change="changeFile" class="customStyle">
<el-button size="mini" type="primary">
添加文件
<i class="el-icon-upload el-icon--right"></i>
</el-button>
<div class="zt-title-video">{{ file.name }}</div>
<div class="zt-progress" v-show="percentageShow">
<el-progress
:text-inside="true"
:stroke-width="20"
:percentage="percentage"
>
</el-progress>
</div>
</div>
*js處理邏輯數(shù)據(jù)*
saveData() { //上傳
let that = this;
let fd = new FormData();
fd.append('file', this.file);
fileUpdata({ //上傳文件存儲(chǔ)在后端
method: 'post',
url: '/uploadVideo',
data: fd,
//監(jiān)聽上傳時(shí)間 //實(shí)現(xiàn)進(jìn)度條
onUploadProgress(progressEvent) {
that.percentageShow = true;
that.percentage = parseInt(((progressEvent.loaded / progressEvent.total) * 100));
}
}).then(res => {
if (res.data.code === 1) {
//數(shù)據(jù)持久化
fileUpdata({
method: 'post',
url: '/saveVideoInfo',
data: {
videoUrl: res.data.videoUrl, //路徑
videoName: res.data.title, //標(biāo)題
videoType:that.videoType, //類型
userName:localStorage.getItem('username') //那個(gè)用戶上傳的
}
}).then(res => {
if (res.data.code === 1) {
setTimeout(function () { //為什么延遲,為了使進(jìn)度條走完
that.$message({
message: '上傳成功',
type: 'success'
})
}, 1000);
}
}).catch(err => {
this.$message.error('服務(wù)器繁忙,請(qǐng)稍后重試!');
});
}
}).catch(err => {
this.$message.error('服務(wù)器繁忙,請(qǐng)稍后重試!');
})
},
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- springboot整合vue實(shí)現(xiàn)上傳下載文件
- vue實(shí)現(xiàn)文件上傳功能
- vue實(shí)現(xiàn)文件上傳讀取及下載功能
- vue.js異步上傳文件前后端實(shí)現(xiàn)代碼
- nodejs multer實(shí)現(xiàn)文件上傳與下載
- nodejs+express實(shí)現(xiàn)文件上傳下載管理網(wǎng)站
- NodeJS使用formidable實(shí)現(xiàn)文件上傳
- Vue實(shí)現(xiàn)附件上傳功能
- 使用Vue實(shí)現(xiàn)圖片上傳的三種方式
- Vue axios 中提交表單數(shù)據(jù)(含上傳文件)
相關(guān)文章
詳解node+express+ejs+bootstrap構(gòu)建項(xiàng)目
本篇文章主要介紹了詳解node+express+ejs+bootstrap構(gòu)建項(xiàng)目,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2017-09-09
NodeJs 實(shí)現(xiàn)簡(jiǎn)單WebSocket即時(shí)通訊的示例代碼
這篇文章主要介紹了NodeJs 實(shí)現(xiàn)簡(jiǎn)單WebSocket即時(shí)通訊的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-08-08
React和Node.js快速上傳進(jìn)度條功能實(shí)現(xiàn)
這篇文章主要為大家介紹了React和Node.js快速上傳進(jìn)度條功能實(shí)現(xiàn)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-03-03
使用NVM實(shí)現(xiàn)不同nodejs版本的自由切換
在工作中,我們可能需要同時(shí)進(jìn)行多個(gè)不同NodeJS版本的項(xiàng)目開發(fā),這種情況下,對(duì)于維護(hù)多個(gè)版本的node將會(huì)是一件非常麻煩的事情,NVM就是為解決這個(gè)問題而產(chǎn)生的,本文給出了下載、安裝及使用方法,需要的朋友可以參考下2024-02-02
詳解nodeJs文件系統(tǒng)(fs)與流(stream)
這篇文章主要介紹了詳解nodeJs文件系統(tǒng)(fs)與流(stream),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-01-01
詳解基于Node.js的微信JS-SDK后端接口實(shí)現(xiàn)代碼
本篇文章主要介紹了詳解基于Node.js的微信JS-SDK后端接口實(shí)現(xiàn)代碼,具有一定的參考價(jià)值,有興趣的可以了解一下2017-07-07
Node.js實(shí)現(xiàn)的簡(jiǎn)易網(wǎng)頁抓取功能示例
這篇文章主要介紹了Node.js實(shí)現(xiàn)的簡(jiǎn)易網(wǎng)頁抓取功能示例,本文使用了PhantomJS、node-phantomjs等庫實(shí)現(xiàn),需要的朋友可以參考下2014-12-12
node+express框架中連接使用mysql(經(jīng)驗(yàn)總結(jié))
這篇文章主要介紹了node+express框架中連接使用mysql(經(jīng)驗(yàn)總結(jié)),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-11-11
nodejs文件操作模塊FS(File System)常用函數(shù)簡(jiǎn)明總結(jié)
這篇文章主要介紹了nodejs文件操作模塊FS(File System)常用函數(shù)簡(jiǎn)明總結(jié),對(duì)FS模塊的大部份異步函數(shù)做了介紹,而且用中文注釋,這下用起來方便了,需要的朋友可以參考下2014-06-06
在Linux系統(tǒng)中搭建Node.js開發(fā)環(huán)境的簡(jiǎn)單步驟講解
這篇文章主要介紹了在Linux系統(tǒng)中搭建Node.js開發(fā)環(huán)境的步驟,Node使得JavaScript程序可以在本地操作系統(tǒng)環(huán)境中解釋運(yùn)行,需要的朋友可以參考下2016-01-01

