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. php遍历对象属性,可以使用foreach,直接打印出属性

    依然遵循私有属性不可以在外访问,(不能打印出来) 但可以在内部访问这个原则.

  2. Linux - 配置SSH免密通信 - “ssh-keygen”的基本用法

    目录 1 什么是SSH 2 配置SSH免密登录 2.1 安装必需的软件 2.2 ssh-keygen创建公钥-私钥对 2.3 ssh-copy-id把A的公钥发送给B 2.4 在A服务器上免密登录B服 ...

  3. linux uart驱动——uart原理(一)

    UART(Universal Asynchronous Receiver and Transmitter)通用异步收发器(异步串行通信口),是一种通用的数据通信协议,它包括了RS232.RS499.R ...

  4. js时间戳格式化成日期格式的多种方法

    js需要把时间戳转为为普通格式,一般的情况下可能用不到的, 下面先来看第一种吧 复制代码代码如下: function getLocalTime(nS) { return new Date(parseI ...

  5. Tomcat 7.0 servlet @WebServlet

    在使用tomcat7.0+eclipse j2ee时,新建Dynamic Web Project时, 会让选择是否生成web.xml.无论选择与否,此时新建一个servlet, 可以不在web.xml ...

  6. Cannot create __weak reference in file using manual reference counting

    Xcode更新到7.3后会出现NSObject+MJProperty.h报Cannot create __weak reference in file using manual reference c ...

  7. 链接数据库代码封装DBDA

    <?php class DBDA { public $host = "localhost"; //服务器地址 public $uid = "root"; ...

  8. Spring 简单描述

    摘抄自知乎 建议不要硬着头皮看spring代码,本身的代码800多m,就是不上班开始看也不知道什么时候看完.如果想学学ioc,控制反转这些建议看看jodd项目,比较简练,但是我仍然不建议过多的看这些框 ...

  9. 【题解】kth异或和/魔改版线性基

    [题解]魔改版线性基 魔改版线性基解决此类问题. 联系线性空间的性质,我们直接可以构造出这样的基: \[ 100000 \\ 010000 \\ 000010 \\ 000001 \] 使得每个基的最 ...

  10. eclipse 安装tomcat