element上传图片组件的方法使用

1.实现最多上传十张图片,超出十张info弹窗提示,(此处可以单独上传超出十张,也可同时上传超出十一张)如图所示

2.用到的组件和涉及到的方法(el-uplaod)

3.上传第十一个附件的时候点击上传附件按钮弹窗提示而不是调起系统的文件窗口需要设置slot

<el-button:slot="fileList.length == limit ? 'tip' : 'trigger'"
                    class="upload-btn"
                    :size="listType !== 'textCard'?'small' : 'mini'"
                    :disabled="disabled"
                    @click="isShowTip"
                    type="primary">上传附件</el-button>
isShowTip () {
      console.log('开始上传', this.fileList)
      if (this.fileList.length == this.limit) {
        // 处理单次上传文件个数超出limit  on-exceed方法
      EventBus.$emit('warning', `最多只能上传${this.limit}个文件`)
      }
    },

3.一次上传超过十个附件,弹窗提示超出用到on-exceed方法;limit是upload属性指向最大上传数

<el-upload action="#"
                :file-list="fileList"
                :class="[listType==='textCard' ? 'textCard' : '']" 
                :limit="limit"
                :on-exceed="_handleExceed">
_handleExceed () {
      // 处理单次上传文件个数超出limit  on-exceed方法
      EventBus.$emit('warning', `最多只能上传${this.limit}个文件`)
    },

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
1. 首先,在项目中安装element-ui和axios: ``` npm install element-ui axios --save ``` 2. 在main.js中引入element-ui和axios: ``` import Vue from 'vue' import ElementUI from 'element-ui' import 'element-ui/lib/theme-chalk/index.css' import axios from 'axios' Vue.use(ElementUI) Vue.prototype.$axios = axios ``` 3. 在组件使用上传组件: ``` <template> <div> <el-upload class="avatar-uploader" action="/api/upload" :show-file-list="false" :on-success="handleSuccess" :before-upload="beforeUpload" > <img v-if="imageUrl" :src="imageUrl" class="avatar"> <i v-else class="el-icon-plus avatar-uploader-icon"></i> </el-upload> </div> </template> ``` 4. 在组件中定义上传前和上传成功的方法: ``` <script> export default { data() { return { imageUrl: '' } }, methods: { beforeUpload(file) { const isJPG = file.type === 'image/jpeg' const isPNG = file.type === 'image/png' if (!isJPG && !isPNG) { this.$message.error('只能上传jpg或png格式的图片') return false } const isLt2M = file.size / 1024 / 1024 < 2 if (!isLt2M) { this.$message.error('上传的图片大小不能超过2MB') return false } return true }, handleSuccess(response) { this.imageUrl = response.data.url } } } </script> ``` 5. 在服务器端,需要接收上传的图片,并将其保存到指定路径: ``` const express = require('express') const multer = require('multer') const path = require('path') const app = express() const storage = multer.diskStorage({ destination: function (req, file, cb) { cb(null, path.join(__dirname, '/public/images')) }, filename: function (req, file, cb) { const extname = path.extname(file.originalname) cb(null, Date.now() + extname) } }) const upload = multer({ storage: storage }) app.post('/api/upload', upload.single('file'), (req, res) => { const url = `http://localhost:3000/images/${req.file.filename}` res.json({ code: 0, data: { url: url } }) }) app.listen(3000, () => { console.log('server is running at http://localhost:3000') }) ``` 以上就是在Vue使用element-ui的上传组件上传图片方法

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值