赞
踩
开发时遇到一个业务需求:
导入时如果当前列表月份存在数据将会提示用户是否要覆盖当前数据,点击确定进行二次提交
直接调用 submit 会无响应,
- this.$confirm(`${response.msg},是否继续?`, '提示', {
- confirmButtonText: 确定,
- cancelButtonText: 取消,
- type: 'warning'
- }).then((res) => {
- // 直接提交会无响应
- this.$refs.upload.submit();
-
- }).catch(() => {})
查询其他资料会发现 大多数会让你 调用
this.$refs["upload"].clearFiles()
这样的话会让用户重新添加,那么如何去节省该步骤呢?
当第一次上传成功后回调 on-success 方法 可以获取到上传的文件,这时可以进行保存
观察el-upload组件源码会发现组件内 存储时有固定的方法handleStart
el-upload组件部分源码:
因此可以自行调用该方法,去主动触发handleStart()方法进行上传
最后贴上正确步骤
- this.$confirm(`${response.msg},是否继续?`, '提示', {
- confirmButtonText: 确定,
- cancelButtonText: 取消,
- type: 'warning'
- }).then((res) => {
- // 先删除
- this.$refs["upload"].clearFiles()
- this.$nextTick(() => {
- // 再导入
- this.$refs["upload"].handleStart(this.fileList[0].raw)
- this.isUpdateSupport = 1
- // 再提交上传
- this.$refs.upload.submit();
- })
-
- }).catch(() => {})
data:image/s3,"s3://crabby-images/deb9d/deb9d52e6c78f73fbfaadc6e519fd00d286664e1" alt=""
User-agent: * Disallow: /
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。