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;

转载于:https://www.cnblogs.com/roddy/p/9244057.html

Logo

前往低代码交流专区

更多推荐