首页 >> js开发 >> jsnode+vue实现文件上传功能js大全
jsnode+vue实现文件上传功能js大全
发布时间: 2021年1月13日 | 浏览:
| 分类:js开发
本文实例为大家分享了node+vue实现文件上传的具体代码,供大家参考,具体内容如下*后端*
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');
//设置 视频文件存放位置
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:'服务器繁忙!'
})
}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:'服务器繁忙!'
})
}
});
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');
//设置 视频文件存放位置
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:'服务器繁忙!'
})
}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:'服务器繁忙!'
})
}
});*前端*
添加文件
:text-inside="true"
:stroke-width="20"
:percentage="percentage"
>
添加文件
:text-inside="true"
:stroke-width="20"
:percentage="percentage"
>
*js处理逻辑数据*
saveData() { //上传
let that = this;
let fd = new FormData();
fd.append('file', this.file);
fileUpdata({ //上传文件存储在后端
method: 'post',
url: '/uploadVideo',
data: fd,
//监听上传时间 //实现进度条
onUploadProgress(progressEvent) {
that.percentageShow = true;
that.percentage = parseInt(((progressEvent.loaded / progressEvent.total) * 100));
}
}).then(res => {
if (res.data.code === 1) {
//数据持久化
fileUpdata({
method: 'post',
url: '/saveVideoInfo',
data: {
videoUrl: res.data.videoUrl, //路径
videoName: res.data.title, //标题
videoType:that.videoType, //类型
userName:localStorage.getItem('username') //那个用户上传的
}
}).then(res => {
if (res.data.code === 1) {
setTimeout(function () { //为什么延迟,为了使进度条走完
that.$message({
message: '上传成功',
type: 'success'
})
}, 1000);
}
}).catch(err => {
this.$message.error('服务器繁忙,请稍后重试!');
});
}
}).catch(err => {
this.$message.error('服务器繁忙,请稍后重试!');
})
},
saveData() { //上传
let that = this;
let fd = new FormData();
fd.append('file', this.file);
fileUpdata({ //上传文件存储在后端
method: 'post',
url: '/uploadVideo',
data: fd,
//监听上传时间 //实现进度条
onUploadProgress(progressEvent) {
that.percentageShow = true;
that.percentage = parseInt(((progressEvent.loaded / progressEvent.total) * 100));
}
}).then(res => {
if (res.data.code === 1) {
//数据持久化
fileUpdata({
method: 'post',
url: '/saveVideoInfo',
data: {
videoUrl: res.data.videoUrl, //路径
videoName: res.data.title, //标题
videoType:that.videoType, //类型
userName:localStorage.getItem('username') //那个用户上传的
}
}).then(res => {
if (res.data.code === 1) {
setTimeout(function () { //为什么延迟,为了使进度条走完
that.$message({
message: '上传成功',
type: 'success'
})
}, 1000);
}
}).catch(err => {
this.$message.error('服务器繁忙,请稍后重试!');
});
}
}).catch(err => {
this.$message.error('服务器繁忙,请稍后重试!');
})
},以上就是本文的全部内容,希望对大家的学习有所帮助。
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');
//设置 视频文件存放位置
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:'服务器繁忙!'
})
}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:'服务器繁忙!'
})
}
});
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');
//设置 视频文件存放位置
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:'服务器繁忙!'
})
}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:'服务器繁忙!'
})
}
});*前端*
添加文件
{{ file.name }}
:text-inside="true"
:stroke-width="20"
:percentage="percentage"
>
添加文件
{{ file.name }}
:text-inside="true"
:stroke-width="20"
:percentage="percentage"
>
saveData() { //上传
let that = this;
let fd = new FormData();
fd.append('file', this.file);
fileUpdata({ //上传文件存储在后端
method: 'post',
url: '/uploadVideo',
data: fd,
//监听上传时间 //实现进度条
onUploadProgress(progressEvent) {
that.percentageShow = true;
that.percentage = parseInt(((progressEvent.loaded / progressEvent.total) * 100));
}
}).then(res => {
if (res.data.code === 1) {
//数据持久化
fileUpdata({
method: 'post',
url: '/saveVideoInfo',
data: {
videoUrl: res.data.videoUrl, //路径
videoName: res.data.title, //标题
videoType:that.videoType, //类型
userName:localStorage.getItem('username') //那个用户上传的
}
}).then(res => {
if (res.data.code === 1) {
setTimeout(function () { //为什么延迟,为了使进度条走完
that.$message({
message: '上传成功',
type: 'success'
})
}, 1000);
}
}).catch(err => {
this.$message.error('服务器繁忙,请稍后重试!');
});
}
}).catch(err => {
this.$message.error('服务器繁忙,请稍后重试!');
})
},
saveData() { //上传
let that = this;
let fd = new FormData();
fd.append('file', this.file);
fileUpdata({ //上传文件存储在后端
method: 'post',
url: '/uploadVideo',
data: fd,
//监听上传时间 //实现进度条
onUploadProgress(progressEvent) {
that.percentageShow = true;
that.percentage = parseInt(((progressEvent.loaded / progressEvent.total) * 100));
}
}).then(res => {
if (res.data.code === 1) {
//数据持久化
fileUpdata({
method: 'post',
url: '/saveVideoInfo',
data: {
videoUrl: res.data.videoUrl, //路径
videoName: res.data.title, //标题
videoType:that.videoType, //类型
userName:localStorage.getItem('username') //那个用户上传的
}
}).then(res => {
if (res.data.code === 1) {
setTimeout(function () { //为什么延迟,为了使进度条走完
that.$message({
message: '上传成功',
type: 'success'
})
}, 1000);
}
}).catch(err => {
this.$message.error('服务器繁忙,请稍后重试!');
});
}
}).catch(err => {
this.$message.error('服务器繁忙,请稍后重试!');
})
},以上就是本文的全部内容,希望对大家的学习有所帮助。
相关文章:
- jsVUE项目axios请求头更改Content-Type操作js大全
- js解决vue的router组件component在import时不能使用变量问题js大全
- js在vue中使用防抖函数组件操作js大全
- jsVue中的this.$options.data()和this.$data用法说明js大全
- jsElement Breadcrumb 面包屑的使用方法js大全
- js解决vue动态路由异步加载import组件,加载不到module的问题js大全
- jsAngular利用HTTP POST下载流文件的步骤记录js大全
- js解决vuex数据页面刷新后初始化操作js大全
- jsvue 页面回退mounted函数不执行的解决方案js大全
- jsvue项目使用$router.go(-1)返回时刷新原来的界面操作js大全