1 UI库使用ElementUI

安装ElementUI

$ npm install --save-dev element-ui

vue加载ElementUI

import ElementUI from 'element-ui' // 导入elementui库
import 'element-ui/lib/theme-chalk/index.css' // 导入样式 Vue.use(ElementUI)

前端组件

<template>
<!-- 图片上传控件 -->
<el-upload
:action="uploadUrl"
list-type="picture-card"
:limit="5"
:on-preview="handlePreview"
:on-remove="handleRemove"
:on-success="handleUploadSuccess">
<i class="el-icon-plus"></i>
</el-upload>
<!-- 图片预览 -->
<el-dialog :visible.sync="dialogVisible">
<img width="100%" :src="dialogImageUrl" alt="">
</el-dialog>
</template> <script>
export default {
data () {
return {
imgs: [], // 已上传图片列表
uploadUrl: '/api/uploadImg', // 图片上传接口地址,自定义
dialogImageUrl: '', // 预览图片地址
dialogVisible: false // 图片预览
}
},
methods: {
// 图片预览
handlePreview (file) {
this.dialogImageUrl = file.url
this.dialogVisible = true
},
/**
* 图片上传成功
* 当上传图片时,ElementUI生成图片的Blob对象,然后本地显示
* 接口返回JSON数据{state: 'success', img: 'xxxxxxxxxxxxx.xxx'}
* 把得到的img存储进this.imgs中
*/
handleUpdateSuccess (res, file, fileList) {
if (res.state === 'success') {
this.imgs.push(res.img) // this.imgs记录已上传成功的图片
}
},
/**
* 图片删除
* 由于图片存储在服务器上,ElementUI图片删除只是删除本地显示
* 所以需要调用服务器图片删除接口,我这里接口为'/api/deleteImg'
* 接口返回JSON格式数据:{state: 'success'}
* 然后从this.imgs中删除图片记录
*/
handleRemove (file, fileList) {
const IMG = file.response.img
const INDEX = this.imgs.indexOf(IMG)
if (INDEX > -1) {
this.$http.delete(`/api/deleteImg/${IMG}`).then((res) => { // 服务器删除图片
const data = res.data
if (data.state === 'success') {
this.imgs.splice(INDEX, 1) // 从this.imgs中删除图片记录
}
}).catch ((err) => {
console.error(err);
})
}
}
}
}
</script>

关于更多element UI上传组件配置

2 后端使用Express + formidable模块

Express安装和使用这里就不详细说明,主要是formidable使用,formidable是一个用来解析表单(尤其文件上传)的node模块

安装 formidable

$ npm install formidable --save

后端代码

const express = require('express');
const router = express.Router();
const path = require('path');
const formidable = require('formidable'); /**
* 上传图片接口
*/
router.post('/uploadImg', function(req, res, next) {
const form = new formidable.IncomingForm();
form.uploadDir = path.join(__dirname, '../upload/img'); // 设置图片路径
form.keepExtensions = true; // 保持扩展名
form.parse(req, function(err, fields, files) {
if (err) throw err;
const saveImgName = files.file.path.split("\\").pop(); // 图片名称
res.json({state: 'success', img: saveImgName}); // 已保存,返回JSON
});
})
/**
* 删除图片接口
*/
router.delete('/deleteImg/:fileName', function(req, res, next) {
const FILE_NAME = req.params.fileName;
const FILE_PATH = path.join(__dirname, `../upload/img/${FILE_NAME}`); // 待删除的图片绝对路径
fs.unlink(FILE_PATH, () => {
res.json({state: 'success'}); // 已删除,返回JSON
})
}) module.exports = router;

vue实现图片的上传和删除的更多相关文章

  1. Vue项目图片剪切上传——vue-cropper的使用

    最近自己在研究vue,然后做了一个小型的后台管理系统用来练手,开发过程中,想到了剪切图片上传用户头像的需求.上网百度了一番,发现好多用的都是vue-cropper.我也就用了,个人感觉还是挺好用的.现 ...

  2. vue里图片压缩上传组件

    //单图上传 <template> <div> <div class="uploader" v-if='!dwimg'> <van-upl ...

  3. NODE 基于express 框架和mongoDB的cookie和session认证 和图片的上传和删除

    源码地址 https://gitee.com/zyqwasd/mongdbSession 本项目的mongodb是本地的mongodb 开启方法可以百度一下 端口是默认的27017 页面效果 1. 注 ...

  4. vue Base64图片压缩上传OSS

    this.compress(result, 800, 0.5).then(val => { //得到压缩图片 let data = val; that.file = that.dataURLto ...

  5. vue中使用cropperjs进行图片裁剪上传

    下面代码直接就可以复制使用了,但是需要在本地下个cropperjs,下载命令:npm install cropperjs --save-dev <template> <div id= ...

  6. 基于vue + axios + lrz.js 微信端图片压缩上传

    业务场景 微信端项目是基于Vux + Axios构建的,关于图片上传的业务场景有以下几点需求: 1.单张图片上传(如个人头像,实名认证等业务) 2.多张图片上传(如某类工单记录) 3.上传图片时期望能 ...

  7. 在vue的element图片的上传及回调

    首先声明,本人用的是element组件写的图片的上传及回调,若非element本方法暂不支持. 下面开始正式讲图片的上传及回调.(本篇拒绝一切花里胡哨,都是干活,言辞粗糙,望请见谅) 1,elemen ...

  8. vue+axios+elementUI文件上传与下载

    vue+axios+elementUI文件上传与下载 Simple_Learn 关注  0.5 2018.05.30 10:20 字数 209 阅读 15111评论 4喜欢 6 1.文件上传 这里主要 ...

  9. Html5+asp.net mvc 图片压缩上传

    在做图片上传时,大图片如果没有压缩直接上传时间会非常长,因为有的图片太大,传到服务器上再压缩太慢了,而且损耗流量. 思路是将图片抽样显示在canvas上,然后用通过canvas.toDataURL方法 ...

随机推荐

  1. 显存不够----ResourceExhaustedError (see above for traceback): OOM when allocating tensor with shape[4096]

    ResourceExhaustedError (see above for traceback): OOM when allocating tensor with shape[4096] 类似问题 h ...

  2. ck-reset css(2016/5/13)

    /**rest by 2016/05/04 */ * {box-sizing: border-box;} *:before,*:after {box-sizing: border-box;} body ...

  3. Mac中遇到的Eclipse连接不上mySql的问题

    1.首先我们在eclipse中连接数据库的过程中,遇到的问题就是如上图.开始百度Communications link failure 这几个关键字.得到的结果基本上就是基本配置参数wait_time ...

  4. 一、Silverlight中使用MVVM(一)——基础

    如果你不知道MVVM模式,我建议你先了解一下MVVM模式,至少要知道实现该模式的意图是什么. 那么我主要通过我认为是已经算是比较简单的例子进行讲解这个模式,当然后面我们会在这个例子的基础上一步一步的进 ...

  5. MySQL 5.7.18的安装及主从复制(主从同步)

    MySQL 5.7.18的安装与主从复制 IP 计算机名 角色 192.168.1.222 001 master 192.168.1.233 002 slave CentOS 6.9安装mysql5. ...

  6. JavaScript系列问题

    JavaScript系列问题:  0.javascript 基础教程[温故而知新一] 1.通过JS变更页面字体的大小 2.图片压缩优化能有效提高网站浏览速度

  7. erlang中的图片下载

    问题如题,这是在一个群里问的一个的问题.其实就是http的Server的上传下载的功能.  ibrowse:start().ibrowse:send_req("http://img1.gti ...

  8. 膨胀和腐蚀 - cvErode() 和 cvDilate() 函数实现

    前言 膨胀就是对图中的每个像素取其核范围内最大的那个值,腐蚀就相反.这两个操作常用来突出显示图的某个高亮部分或者昏暗部分以及去噪.本文展示两个分别对图像进行膨胀和腐蚀的例子. 膨胀和腐蚀函数 cvEr ...

  9. ios -- 极光推送《1》

    昨天公司项目要加入远程推送功能,自己做显然会很麻烦,所以用了极光的远程推送,下面我会讲如何制作推送证书并使用极光推送进行远程推送. 先讲讲怎么下载推送证书吧(前面的很简单要是知道的可以直接往下滑,简书 ...

  10. GS(道具,帮会)定时存储

    //最近数据库存储做了重大改变,数据库内部的回头再说,先看看GS这边的 .现在感觉数据库的状态将请求包放入命令队列中,以前是全部放进去,这样让其他的数据库操作不会随着数据库定时器而变慢,GS线程去驱动 ...