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
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
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
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
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
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