Yb-components Yb-components
首页
开发规范
yb-cli
  • 开发指南
  • 更新日志
  • 组件
关于
首页
开发规范
yb-cli
  • 开发指南
  • 更新日志
  • 组件
关于
  • 开发指南
  • 更新日志
  • 数据展示

    • YbTable 表格
    • YbCardList 卡片列表
    • YbTree 树
    • YbCascaderList 级联列表
    • YbSimpleTablePage 分页查询表格
    • YbSimpleCardPage 分页卡片列表
    • YbBasicProfile 基础详情数据展示
    • YbOutscrollLayout 固定在滚动区域外
    • YbOutscrollTree 固定在滚动区域外的Tree
    • YbInfoLayout 信息页布局
    • YbEditLayout 编辑页布局
  • 数据录入

    • YbRowsPopoverForm 浮层多行表单
    • YbFormily 配置式表单
    • YbForm 表单
    • YbRowsForm 多行表单
    • YbCollapseForm 折叠表单
    • YbQueryFilter 筛选表单
    • YbFilesSelect 文件选择器
      • YbRangeWrapper 范围结构
      • YbRangeDatepicker 日期范围
      • YbRange 范围
      • YbFormulaInput 简单运算公式输入
      • YbCron 表达式生成器
      • YbTreeSelect 树型选择器
      • YbInputgroupWrapper 复合组
      • YbThemeSelect 主题风格选择器
      • YbSelect 选择器
      • YbPaginationSelect 分页选择器
      • YbCodemirror 代码编辑器
      • YbCodemirrorSql SQL编辑器
      • YbCodemirrorJson JSON编辑器
      • YbCodemirrorXml XML编辑器
      • YbCombiDatepicker 组合时间
      • YbQuarterPicker 季度选择器
      • YbRangeQuarterPicker 季度范围选择器
      • YbConditionSelect 条件选择器
      • YbCheckboxGroup 多选框组
      • YbIconSelect 选择器
      • YbTagsInput 标签输入框
    • 其他组件

      • YbBallLoading 加载中
      • YbSymbolIcon 多色小图标
      • YbKeybuttonsPopover
      • YbPercentBattery 电池百分比
      • YbAffix 固钉
      • YbPagination 分页器
      • YbCollapse 折叠面板
      • YbScrollTool 滚动工具
    • 物料

      • YbMainSideMenu 侧栏菜单
      • YbLoadRemote 远程应用加载
      • YbLayoutPro 布局
      • YbMainPro 主页
      • YbAppMain 应用主页
      • YbAppLogin 普通登录页
      • YbAppPortal Portal登录页
    • 指令

      • v-fixed-in-scroller
    • Mixins

      • pageList_mixin
      • getScopedSlot_mixin
      • editFormPage_mixin
      • uploadProgressPage_mixin
      • rowActions_mixin
      • rowDeletes_mixin
      • drawerToRouterTab_mixin
    • 实验室

      • YbSwiper 轮播
    • 组件
    • 数据录入
    zougt
    2022-05-17

    YbFilesSelect 文件选择器

    在el-upload基础上封装成一个 v-model 形式的选择文件的组件,可以直接用于表单当中,选择文件后不自动上传。

    # 基本使用

    默认使用的 el-upload 属性有:

    • drag:true
    • multiple:true
    • accept:'.xlsx,.xls,application/vnd.ms-excel,application/vnd.openxmlformats-officedocument.spreadsheetml.sheet'
    • 'auto-upload': false
    • limit:1
    将上传文件拖到此处,或点击选择
      <template>
          <yb-files-select v-model="value" :limit="10" />
      </template>
      <script>
          export default {
              data() {
                  return {
                      value: null,
                  };
              },
              watch: {
                  value: function () {
                      console.log(this.value);
                  },
              },
          };
      </script>
      
      1
      2
      3
      4
      5
      6
      7
      8
      9
      10
      11
      12
      13
      14
      15
      16
      17
      显示 复制 复制

      # 回显值

      选择文件后得到的 value 是 File (opens new window)对象的数组,上传到服务端后,返显组件值可以是 object[]

      将上传文件拖到此处,或点击选择
      • food.jpeg 按 delete 键可删除
      • food2.jpeg 按 delete 键可删除
      <template>
          <yb-files-select v-model="value" :limit="10" accept="image/*" />
      </template>
      <script>
          export default {
              data() {
                  return {
                      value: [
                          {
                              name: 'food.jpeg',
                              url: 'https://fuss10.elemecdn.com/3/63/4e7f3a15429bfda99bce42a18cdd1jpeg.jpeg?imageMogr2/thumbnail/360x360/format/webp/quality/100',
                          },
                          {
                              name: 'food2.jpeg',
                              url: 'https://fuss10.elemecdn.com/3/63/4e7f3a15429bfda99bce42a18cdd1jpeg.jpeg?imageMogr2/thumbnail/360x360/format/webp/quality/100',
                          },
                      ],
                  };
              },
          };
      </script>
      
      1
      2
      3
      4
      5
      6
      7
      8
      9
      10
      11
      12
      13
      14
      15
      16
      17
      18
      19
      20
      21
      显示 复制 复制

      # 照片墙

      使用 el-upload 的 list-type 属性来设置文件列表的样式。

      • food.jpeg 按 delete 键可删除
      • food2.jpeg 按 delete 键可删除
      <template>
          <yb-files-select
              list-type="picture-card"
              :drag="false"
              v-model="value"
              :limit="10"
              accept="image/*"
              drag-message="99999"
          >
          </yb-files-select>
      </template>
      <script>
          export default {
              data() {
                  return {
                      value: [
                          {
                              name: 'food.jpeg',
                              url: 'https://fuss10.elemecdn.com/3/63/4e7f3a15429bfda99bce42a18cdd1jpeg.jpeg?imageMogr2/thumbnail/360x360/format/webp/quality/100',
                          },
                          {
                              name: 'food2.jpeg',
                              url: 'https://fuss10.elemecdn.com/3/63/4e7f3a15429bfda99bce42a18cdd1jpeg.jpeg?imageMogr2/thumbnail/360x360/format/webp/quality/100',
                          },
                      ],
                  };
              },
          };
      </script>
      
      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
      显示 复制 复制

      # 在表单中使用

      在 yb-form 中使用很方便

      <template>
          <div>
              <yb-form
                  ref="form"
                  :formItems="formItems"
                  :model="formModel"
                  label-width="100px"
                  @submit.native.prevent="onSubmit"
              >
                  <template v-slot:formItems="formItem">
                      <el-input
                          v-model="formModel[formItem.prop]"
                          clearable
                      ></el-input>
                  </template>
                  <template v-slot:excelFiles="formItem">
                      <yb-files-select
                          v-model="formModel[formItem.prop]"
                          :limit="10"
                      />
                  </template>
                  <template v-slot:buttons="formItem">
                      <el-button type="primary" native-type="submit">提交</el-button>
                      <el-button>取消</el-button>
                  </template>
              </yb-form>
          </div>
      </template>
      <script>
          export default {
              data() {
                  const formItems = [
                      {
                          label: '标题',
                          prop: 'title',
                          rules: [
                              {
                                  required: true,
                                  message: '请输入',
                                  trigger: 'blur',
                              },
                          ],
                          defaultValue: '',
                      },
                      {
                          label: 'excel文件',
                          prop: 'excelFiles',
                          rules: [
                              {
                                  required: true,
                                  message: '请选择excel文件',
                                  trigger: 'change',
                              },
                          ],
                      },
                      {
                          label: '',
                          prop: 'buttons',
                      },
                  ];
                  const formModel = formItems.reduce((tol, item) => {
                      return {
                          ...tol,
                          [item.prop]:
                              typeof item.defaultValue !== 'undefined'
                                  ? item.defaultValue
                                  : null,
                      };
                  }, {});
                  return {
                      formItems,
                      formModel,
                  };
              },
              methods: {
                  onSubmit() {
                      this.$refs['form']
                          .getForm()
                          .validate()
                          .then(() => {
                              const values = { ...this.formModel };
                              const formData = new FormData();
                              Object.keys(values).forEach((key) => {
                                  if (
                                      Array.isArray(values[key]) &&
                                      Object.prototype.toString.call(
                                          values[key][0]
                                      ) === '[object File]'
                                  ) {
                                      values[key].forEach((item) => {
                                          formData.append(key, item);
                                      });
                                      delete values[key];
                                  }
                              });
      
                              console.log('验证成功', values, formData);
                          })
                          .catch((err, errFields) => {
                              console.log('验证失败', err, errFields);
                          });
                  },
              },
          };
      </script>
      
      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
      73
      74
      75
      76
      77
      78
      79
      80
      81
      82
      83
      84
      85
      86
      87
      88
      89
      90
      91
      92
      93
      94
      95
      96
      97
      98
      99
      100
      101
      102
      103
      104
      105
      显示 复制 复制

      # 选择图片转成 base64 提交

      在 yb-form 中与其他字段一起提交

      <template>
          <div>
              <yb-form
                  ref="form"
                  :formItems="formItems"
                  :model="formModel"
                  label-width="100px"
                  @submit.native.prevent="onSubmit"
              >
                  <template v-slot:formItems="formItem">
                      <el-input
                          v-model="formModel[formItem.prop]"
                          clearable
                      ></el-input>
                  </template>
                  <template v-slot:fileImages="formItem">
                      <yb-files-select
                          list-type="picture-card"
                          :drag="false"
                          v-model="formModel[formItem.prop]"
                          :limit="10"
                          accept="image/*"
                      >
                      </yb-files-select>
                  </template>
                  <template v-slot:buttons="formItem">
                      <el-button type="primary" native-type="submit">提交</el-button>
                      <el-button>取消</el-button>
                  </template>
              </yb-form>
          </div>
      </template>
      <script>
          export default {
              data() {
                  const formItems = [
                      {
                          label: '标题',
                          prop: 'title',
                          rules: [
                              {
                                  required: true,
                                  message: '请输入',
                                  trigger: 'blur',
                              },
                          ],
                      },
                      {
                          label: 'base64图片',
                          prop: 'fileImages',
                          rules: [
                              {
                                  required: true,
                                  message: '请选择图片',
                                  trigger: 'change',
                              },
                          ],
                          defaultValue: [
                              {
                                  name: '测试图片',
                                  url: '',
                              },
                          ],
                      },
                      {
                          label: '',
                          prop: 'buttons',
                      },
                  ];
                  const formModel = formItems.reduce((tol, item) => {
                      return {
                          ...tol,
                          [item.prop]:
                              typeof item.defaultValue !== 'undefined'
                                  ? item.defaultValue
                                  : null,
                      };
                  }, {});
                  return {
                      formItems,
                      formModel,
                  };
              },
              methods: {
                  onSubmit() {
                      this.$refs['form']
                          .getForm()
                          .validate()
                          .then(() => {
                              const values = { ...this.formModel };
                              // fileImages 可能是[{name:'aaa.png',url:'base64'},file,file]
                              const allP = Promise.all(
                                  values.fileImages.map((file) => {
                                      if (
                                          Object.prototype.toString.call(file) ===
                                          '[object File]'
                                      ) {
                                          return new Promise((resolve, reject) => {
                                              const oFileReader = new FileReader();
                                              oFileReader.readAsDataURL(file);
                                              oFileReader.onload = (e) => {
                                                  const base64 = e.target.result;
                                                  resolve(base64);
                                              };
                                              oFileReader.onerror = reject;
                                          });
                                      }
                                      return Promise.resolve(file.url);
                                  })
                              );
                              allP.then((fileArr) => {
                                  values.fileImages = fileArr;
                                  console.log('验证成功', values);
                              });
                          })
                          .catch((err, errFields) => {
                              console.log('验证失败', err, errFields);
                          });
                  },
              },
          };
      </script>
      
      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
      73
      74
      75
      76
      77
      78
      79
      80
      81
      82
      83
      84
      85
      86
      87
      88
      89
      90
      91
      92
      93
      94
      95
      96
      97
      98
      99
      100
      101
      102
      103
      104
      105
      106
      107
      108
      109
      110
      111
      112
      113
      114
      115
      116
      117
      118
      119
      120
      121
      122
      显示 复制 复制

      # Props

      参数 说明 类型 可选值 默认值
      value / v-model 绑定值 object[] / file[] -- --
      limit 最大选择数量 number -- 1
      dragMessage 可拖动文件到的位置的文字描述 ,因为组件默认是开启 drag 属性的 string -- 将上传文件拖到此处,或
      ... 其他属性同 el-upload (opens new window) -- -- --
      上次更新: 2023/08/18, 17:53:01
      YbQueryFilter 筛选表单
      YbRangeWrapper 范围结构

      ← YbQueryFilter 筛选表单 YbRangeWrapper 范围结构→

      Theme by Vdoing | Copyright © 2021-2025 YB-GZ | MIT License
      • 跟随系统
      • 浅色模式
      • 深色模式
      • 阅读模式