分支自 SuZhouGuanHong/TaiYuanTaiZhong

WMS
dengjunjie
2023-12-13 d772a6cddc8ed656a2cb5604fc02f6e891db546e
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
<template>
  <VolBox
    v-model="model"
    title="选择图片"
    :height="228"
    :width="500"
    :padding="15"
  >
    <!-- 上传图片、excel或其他文件、文件数量、大小限制都可以,参照volupload组件api -->
    <div style="height: 150px;">
      <VolUpload
      style="text-align: center; border: 1px dotted #ff9800; padding: 20px"
      :autoUpload="false"
      :multiple="true"
      :url="url"
      :max-file="2"
      :img="true"
      :fileInfo="fileInfo"
      :upload-after="uploadAfter"
    >
      <div>选择图片,只能上传3M以内的照片</div>
    </VolUpload>
    </div>
  </VolBox>
</template>
<script>
import { h, resolveComponent, defineAsyncComponent } from "vue";
export default {
  components: {
    VolUpload: defineAsyncComponent(() =>
      import("@/components/basic/VolUpload.vue")
    ),
    VolBox: defineAsyncComponent(() => import("@/components/basic/VolBox.vue")),
  },
  data() {
    return {
      //设置保存图片的路径,此处选择的是框架自带每个表的上传的路径
      //也可以自定义设置上传文件的接口,如果需要上传到第三方请实现uploadBefore方法
      url: "api/Sys_Dictionary/upload",
      fileInfo: [], //初始化一个空对象,用来存储编辑上传图片时的原始图片
      model: false,
      row: {}, //当前操作的明细表行
    };
  },
  methods: {
    open(fileInfo, row) {
      this.row=row;
      this.fileInfo = fileInfo;
      this.model = true;
    },
    //上传完成,将图片写入明细表数据
    uploadAfter(result, files) {
      if (!result.status) return true;
      //生成图片保存后返回的路径
      let imgs = files.map((x) => {
        //2021.09.25修复示例上传路径逻辑错误的问题
        if (x.path) {
          return x.path;
        }
        return result.data + x.name;
      });
      // //获取vue父组件(查询界面)
      // this.$emit('parentCall',($parent)=>{
      // })
      //将图片通过逗号隔开,重新写入明细表的行数据中
      this.row.Remark = imgs.join(",");
      this.model = false;
      return true;
    },
  },
};
</script>