elemet-ui里提供的upload文件上传组件,功能很强大,能满足单独使用的需求,但是有时候会存在多次复用上传组件的需求,如下图的样子,这时候就出现了问题,页面上有多个上传组件时,要怎么操作呢?
data:image/s3,"s3://crabby-images/302fe/302fe56b940369e79f9e74b7d9b54d33eefe1d3c" alt=""
解决方案1 修改源码(看到一位大神推荐的)
1、找到node_modules/element-ui/lib/element-ui.common.js文件
data:image/s3,"s3://crabby-images/92e84/92e8478add600b2a4a49424b8c4c132032dc6ec0" alt=""
2、在里面的props里多加一个传递的参数,自定义参数名
onPreview: {
type: Function
},
/*这个是新加的 start*/
objectBind:null,
/*这个是新加的 end*/
onSuccess: {
type: Function,
default: noop
},
3、接着往下找到你需要用到的函数,在参数里加上你新增的这个参数this.objectBind
data:image/s3,"s3://crabby-images/b9947/b9947ff65667787e1d0e28acaced6400052932ca" alt=""
4、回到项目中,在引用的时候把这个参数传进去,一般是索引,利用索引去匹配
data:image/s3,"s3://crabby-images/6c866/6c866fd19bb26a4ddc7b7bcb1fb1e5d021c03380" alt=""
解决方案2 自己进行二次封装
- 利用闭包的写法,把默认的参数和自己新增的参数作为一个新的函数返回,拿到索引值,进行相关逻辑处理
:on-success="function (res,file){return handleImgSuccess(res,file,scope.$index)}"
data:image/s3,"s3://crabby-images/40936/409365acb633c38a45468f333976ef36c579d8d8" alt=""
网友评论