lxui-uni 0.0.2 → 0.0.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/components/lx-header/lx-header.vue +250 -0
- package/{lib → components/lx-hello}/lx-hello.vue +5 -0
- package/components/lx-image/index.ts +3 -0
- package/components/lx-image/lx-image.vue +102 -0
- package/components/lx-list/lx-list.vue +162 -0
- package/components/lx-list-state/lx-list-state.vue +92 -0
- package/components/lx-operate-bottom/lx-operate-bottom.vue +107 -0
- package/components/lx-submit-btn/lx-submit-btn.vue +61 -0
- package/components/lx-upload/lx-upload.vue +192 -0
- package/index.ts +11 -4
- package/package.json +2 -2
- package/theme.scss +228 -0
- package/types/components.d.ts +23 -0
- package/util/index.ts +294 -0
- package/util/useListLoadClass.ts +143 -0
- package/vite.config.ts +1 -0
- package/lib/lx-image.vue +0 -82
|
@@ -0,0 +1,92 @@
|
|
|
1
|
+
<script lang="ts" setup>
|
|
2
|
+
/** * 传参说明
|
|
3
|
+
* @param imgUrl 默认图
|
|
4
|
+
* @param imgIsShow 默认图是否展示
|
|
5
|
+
* @param tips 默认提示语
|
|
6
|
+
* */
|
|
7
|
+
defineProps({
|
|
8
|
+
// 分页加载数据有无下一页
|
|
9
|
+
isNoData: {
|
|
10
|
+
type: Boolean,
|
|
11
|
+
default: false
|
|
12
|
+
},
|
|
13
|
+
// 正在加载中
|
|
14
|
+
isLoading: {
|
|
15
|
+
type: Boolean,
|
|
16
|
+
default: false
|
|
17
|
+
},
|
|
18
|
+
// 暂无数据
|
|
19
|
+
isEmpty: {
|
|
20
|
+
type: Boolean,
|
|
21
|
+
default: false
|
|
22
|
+
},
|
|
23
|
+
// 暂无数据使用
|
|
24
|
+
imgUrl: {
|
|
25
|
+
type: String,
|
|
26
|
+
default: ''
|
|
27
|
+
},
|
|
28
|
+
imgIsShow: {
|
|
29
|
+
type: Boolean,
|
|
30
|
+
default: true
|
|
31
|
+
},
|
|
32
|
+
tips: {
|
|
33
|
+
type: String,
|
|
34
|
+
default: '暂无数据~'
|
|
35
|
+
}
|
|
36
|
+
})
|
|
37
|
+
</script>
|
|
38
|
+
|
|
39
|
+
<template>
|
|
40
|
+
<view class="list_state_box">
|
|
41
|
+
<view class="flex empty column" v-if="isEmpty">
|
|
42
|
+
<slot>
|
|
43
|
+
<view class="img" v-if="imgIsShow">
|
|
44
|
+
<image :src="imgUrl" mode="widthFix"></image>
|
|
45
|
+
</view>
|
|
46
|
+
</slot>
|
|
47
|
+
<view class="txt">
|
|
48
|
+
{{ tips }}
|
|
49
|
+
</view>
|
|
50
|
+
</view>
|
|
51
|
+
<view class="list_state" v-else>
|
|
52
|
+
<view class="txt" v-if="isLoading">正在努力加载更多~</view>
|
|
53
|
+
<view class="txt" v-else-if="isNoData && isNoData == true">已加载全部~</view>
|
|
54
|
+
<view class="txt" v-if="!isLoading && !isNoData">上拉加载更多~</view>
|
|
55
|
+
</view>
|
|
56
|
+
</view>
|
|
57
|
+
</template>
|
|
58
|
+
<style lang="scss">
|
|
59
|
+
.list_state_box {
|
|
60
|
+
.list_state {
|
|
61
|
+
margin: 30rpx 0;
|
|
62
|
+
|
|
63
|
+
.txt {
|
|
64
|
+
text-align: center;
|
|
65
|
+
color: #666;
|
|
66
|
+
margin: 10rpx 0;
|
|
67
|
+
font-size: 28rpx;
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
.empty {
|
|
72
|
+
min-height: 60vh;
|
|
73
|
+
.txt {
|
|
74
|
+
font-size: 26rpx;
|
|
75
|
+
color: #666;
|
|
76
|
+
text-align: center;
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
.img {
|
|
80
|
+
width: 70%;
|
|
81
|
+
// max-height: 300rpx;
|
|
82
|
+
margin: 0 auto;
|
|
83
|
+
text-align: center;
|
|
84
|
+
|
|
85
|
+
image {
|
|
86
|
+
width: 100%;
|
|
87
|
+
// height: 100%;
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
</style>
|
|
@@ -0,0 +1,107 @@
|
|
|
1
|
+
<script setup lang="ts">
|
|
2
|
+
/*
|
|
3
|
+
* @description: 底部安全距离盒子
|
|
4
|
+
* @fileName: lx-safety-bottom.vue
|
|
5
|
+
* @params
|
|
6
|
+
* @author: lxx
|
|
7
|
+
* @date: 2024-02-26 11:24:59"
|
|
8
|
+
* @version: V1.0.0
|
|
9
|
+
*/
|
|
10
|
+
interface PropsInt {
|
|
11
|
+
leftTxt: string
|
|
12
|
+
rightConfirmTxt: string
|
|
13
|
+
rightCancelTxt: string
|
|
14
|
+
discount: string
|
|
15
|
+
amount: string
|
|
16
|
+
}
|
|
17
|
+
withDefaults(defineProps<PropsInt>(), {
|
|
18
|
+
leftTxt: '',
|
|
19
|
+
rightConfirmTxt: '',
|
|
20
|
+
rightCancelTxt: '',
|
|
21
|
+
discount: '',
|
|
22
|
+
amount: ''
|
|
23
|
+
})
|
|
24
|
+
const emit = defineEmits(['confirm', 'cancel'])
|
|
25
|
+
const confirmClick = () => emit('confirm')
|
|
26
|
+
const cancelClick = () => emit('cancel')
|
|
27
|
+
</script>
|
|
28
|
+
<template>
|
|
29
|
+
<view class="lx_safety_bottom flex-center-between">
|
|
30
|
+
<view class="bottom_left_box">
|
|
31
|
+
<slot name="left">
|
|
32
|
+
<view class="amount_box flex-center" v-if="discount">
|
|
33
|
+
<view class="amount">¥{{ amount }}</view>
|
|
34
|
+
<view class="discount">¥{{ discount }}</view>
|
|
35
|
+
</view>
|
|
36
|
+
<view v-if="leftTxt" class="left_txt text-ellipsis">{{ leftTxt }}</view>
|
|
37
|
+
</slot>
|
|
38
|
+
</view>
|
|
39
|
+
<view class="bottom_right_box">
|
|
40
|
+
<slot name="right">
|
|
41
|
+
<view class="flex">
|
|
42
|
+
<view class="cancel_btn" v-if="rightCancelTxt" @click="cancelClick">{{ rightCancelTxt }}</view>
|
|
43
|
+
<view class="sub_btn" v-if="rightConfirmTxt" @click="confirmClick">{{ rightConfirmTxt }}</view>
|
|
44
|
+
</view>
|
|
45
|
+
</slot>
|
|
46
|
+
</view>
|
|
47
|
+
</view>
|
|
48
|
+
<view class="lx_safety_bottom_mark"></view>
|
|
49
|
+
</template>
|
|
50
|
+
<style lang="scss" scoped>
|
|
51
|
+
.lx_safety_bottom_mark {
|
|
52
|
+
/* 兼容 iOS < 11.2 */
|
|
53
|
+
padding-bottom: constant(safe-area-inset-bottom);
|
|
54
|
+
/* 兼容 iOS >= 11.2 */
|
|
55
|
+
padding-bottom: calc(env(safe-area-inset-bottom) + 6rpx);
|
|
56
|
+
height: 100rpx;
|
|
57
|
+
// box-sizing: border-box;
|
|
58
|
+
}
|
|
59
|
+
.lx_safety_bottom {
|
|
60
|
+
position: fixed;
|
|
61
|
+
left: 0;
|
|
62
|
+
width: calc(100% - 72rpx);
|
|
63
|
+
bottom: 0;
|
|
64
|
+
/* 兼容 iOS < 11.2 */
|
|
65
|
+
padding-bottom: constant(safe-area-inset-bottom);
|
|
66
|
+
/* 兼容 iOS >= 11.2 */
|
|
67
|
+
padding-bottom: calc(env(safe-area-inset-bottom) + 6rpx);
|
|
68
|
+
// height: 100rpx;
|
|
69
|
+
background-color: rgb(255, 255, 255);
|
|
70
|
+
padding-left: 36rpx;
|
|
71
|
+
padding-right: 36rpx;
|
|
72
|
+
padding-top: 10rpx;
|
|
73
|
+
// box-sizing: border-box;
|
|
74
|
+
.bottom_left_box {
|
|
75
|
+
// max-width: 70%;
|
|
76
|
+
// 普通文本
|
|
77
|
+
.left_txt {
|
|
78
|
+
font-size: $font-size-40;
|
|
79
|
+
font-weight: 700;
|
|
80
|
+
color: $main-color;
|
|
81
|
+
}
|
|
82
|
+
// 金额+优惠金额
|
|
83
|
+
.amount_box {
|
|
84
|
+
font-size: $font-size-40;
|
|
85
|
+
.amount {
|
|
86
|
+
font-weight: 700;
|
|
87
|
+
color: $main-color;
|
|
88
|
+
}
|
|
89
|
+
.discount {
|
|
90
|
+
padding-left: 30rpx;
|
|
91
|
+
text-decoration-line: line-through;
|
|
92
|
+
color: rgba(166, 166, 166, 1);
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
.bottom_right_box {
|
|
97
|
+
.sub_btn {
|
|
98
|
+
@include btn-solid;
|
|
99
|
+
}
|
|
100
|
+
.cancel_btn {
|
|
101
|
+
@include btn-line;
|
|
102
|
+
margin-right: 8rpx;
|
|
103
|
+
border-radius: 8rpx;
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
</style>
|
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
<script setup lang="ts">
|
|
2
|
+
/*
|
|
3
|
+
* @description: 提交按钮组件
|
|
4
|
+
* @fileName: lx-submit-btn.vue
|
|
5
|
+
* @params
|
|
6
|
+
* @author: lxx 2399270194@qq.com
|
|
7
|
+
* @date: 2024-02-27 14:58:31"
|
|
8
|
+
* @version: V1.0.0
|
|
9
|
+
*/
|
|
10
|
+
interface PropsInt {
|
|
11
|
+
text: string
|
|
12
|
+
loading?: boolean
|
|
13
|
+
}
|
|
14
|
+
withDefaults(defineProps<PropsInt>(), {
|
|
15
|
+
text: '提交',
|
|
16
|
+
loading: false
|
|
17
|
+
})
|
|
18
|
+
const emit = defineEmits(['submit'])
|
|
19
|
+
</script>
|
|
20
|
+
<template>
|
|
21
|
+
<view class="submit_btn_box">
|
|
22
|
+
<button class="submit_btn" :loading="loading" @click="emit('submit')">{{ text }}</button>
|
|
23
|
+
</view>
|
|
24
|
+
<view class="submit_mark_box"></view>
|
|
25
|
+
</template>
|
|
26
|
+
<style lang="scss" scoped>
|
|
27
|
+
.submit_mark_box {
|
|
28
|
+
padding-bottom: constant(safe-area-inset-bottom);
|
|
29
|
+
/* 兼容 iOS >= 11.2 */
|
|
30
|
+
padding-bottom: env(safe-area-inset-bottom);
|
|
31
|
+
padding-top: 10rpx;
|
|
32
|
+
height: 92rpx;
|
|
33
|
+
}
|
|
34
|
+
.submit_btn_box {
|
|
35
|
+
padding: 0 28rpx;
|
|
36
|
+
/* 兼容 iOS < 11.2 */
|
|
37
|
+
padding-bottom: constant(safe-area-inset-bottom);
|
|
38
|
+
/* 兼容 iOS >= 11.2 */
|
|
39
|
+
padding-bottom: env(safe-area-inset-bottom);
|
|
40
|
+
padding-top: 10rpx;
|
|
41
|
+
position: fixed;
|
|
42
|
+
bottom: 10rpx;
|
|
43
|
+
left: 50%;
|
|
44
|
+
transform: translateX(-50%);
|
|
45
|
+
width: 100%;
|
|
46
|
+
|
|
47
|
+
.submit_btn {
|
|
48
|
+
margin: 0 auto;
|
|
49
|
+
width: 96%;
|
|
50
|
+
box-sizing: border-box;
|
|
51
|
+
border-radius: 8rpx;
|
|
52
|
+
background: $main-color;
|
|
53
|
+
font-size: $font-size-28;
|
|
54
|
+
font-weight: 400;
|
|
55
|
+
line-height: 92rpx;
|
|
56
|
+
text-align: center;
|
|
57
|
+
color: rgba(255, 255, 255, 1);
|
|
58
|
+
height: 92rpx;
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
</style>
|
|
@@ -0,0 +1,192 @@
|
|
|
1
|
+
<script setup lang="ts">
|
|
2
|
+
/*
|
|
3
|
+
* @description: 上传组件
|
|
4
|
+
* @fileName: lx-upload.vue
|
|
5
|
+
* @params
|
|
6
|
+
* @author: lxx
|
|
7
|
+
* @date: 2024-03-08 14:08:27"
|
|
8
|
+
* @version: V1.0.0
|
|
9
|
+
*/
|
|
10
|
+
import { getCurrentInstance, onMounted, ref } from 'vue'
|
|
11
|
+
const baseUrl = import.meta.env.VITE_APP_BASE_URL
|
|
12
|
+
const delIcon = ''
|
|
13
|
+
const addIcon = ''
|
|
14
|
+
interface propsInt {
|
|
15
|
+
width: string // 盒子宽度
|
|
16
|
+
radius: string // 盒子圆角
|
|
17
|
+
spacing: number // 间隔
|
|
18
|
+
rowNum: number // 一行的盒子数
|
|
19
|
+
limit: number // 最多上传个数
|
|
20
|
+
modelValue: string[] | string // 上传的图片
|
|
21
|
+
}
|
|
22
|
+
const props = withDefaults(defineProps<propsInt>(), {
|
|
23
|
+
radius: '16rpx',
|
|
24
|
+
spacing: 10,
|
|
25
|
+
rowNum: 3,
|
|
26
|
+
limit: 3,
|
|
27
|
+
modelValue: () => []
|
|
28
|
+
})
|
|
29
|
+
const emit = defineEmits(['update:modelValue'])
|
|
30
|
+
// 上传
|
|
31
|
+
const uploadAdd = () => {
|
|
32
|
+
uni.chooseImage({
|
|
33
|
+
count: 1, //默认9
|
|
34
|
+
// sizeType: ['original', 'compressed'], //可以指定是原图还是压缩图,默认二者都有
|
|
35
|
+
// sourceType: ['album'], //从相册选择
|
|
36
|
+
success: (chooseImageRes) => {
|
|
37
|
+
const tempFilePaths = chooseImageRes.tempFilePaths
|
|
38
|
+
uni.uploadFile({
|
|
39
|
+
url: baseUrl + '/api/v1.Resources/upload',
|
|
40
|
+
filePath: tempFilePaths[0],
|
|
41
|
+
name: 'file',
|
|
42
|
+
success: (uploadFileRes: any) => {
|
|
43
|
+
const { data, code } = JSON.parse(uploadFileRes.data)
|
|
44
|
+
if (code === 200) {
|
|
45
|
+
// 如果是一张图片传入数据可以是字符串
|
|
46
|
+
if (props.limit === 1) {
|
|
47
|
+
emit('update:modelValue', data)
|
|
48
|
+
} else {
|
|
49
|
+
// eslint-disable-next-line prettier/prettier
|
|
50
|
+
(props.modelValue as string[]).push(data)
|
|
51
|
+
emit('update:modelValue', props.modelValue)
|
|
52
|
+
}
|
|
53
|
+
} else {
|
|
54
|
+
uni.showToast({
|
|
55
|
+
title: '上传失败',
|
|
56
|
+
icon: 'none',
|
|
57
|
+
mask: true
|
|
58
|
+
})
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
})
|
|
62
|
+
}
|
|
63
|
+
})
|
|
64
|
+
}
|
|
65
|
+
// 删除
|
|
66
|
+
const uploadDel = (index?: number) => {
|
|
67
|
+
if (props.limit === 1) {
|
|
68
|
+
emit('update:modelValue', '')
|
|
69
|
+
} else {
|
|
70
|
+
// eslint-disable-next-line prettier/prettier, no-extra-semi
|
|
71
|
+
;(props.modelValue as string[]).splice(index as number, 1)
|
|
72
|
+
emit('update:modelValue', props.modelValue)
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
// 盒子宽度
|
|
76
|
+
const boxWidth = ref('')
|
|
77
|
+
onMounted(() => {
|
|
78
|
+
const query = uni.createSelectorQuery().in(getCurrentInstance())
|
|
79
|
+
query
|
|
80
|
+
.select('.lx_upload_box')
|
|
81
|
+
.boundingClientRect((data: any) => {
|
|
82
|
+
// console.log('得到布局位置信息' + data)
|
|
83
|
+
// console.log('节点离页面顶部的距离为' + data.width, Math.floor(data.width))
|
|
84
|
+
// 没有传大小就计算大小
|
|
85
|
+
if (!props.width) {
|
|
86
|
+
boxWidth.value = Math.floor((data.width - props.spacing * (props.rowNum - 1)) / props.rowNum) + 'px'
|
|
87
|
+
console.log(boxWidth.value, ' boxWidth.value')
|
|
88
|
+
} else {
|
|
89
|
+
boxWidth.value = props.width
|
|
90
|
+
}
|
|
91
|
+
})
|
|
92
|
+
.exec()
|
|
93
|
+
})
|
|
94
|
+
|
|
95
|
+
const previewImage = (urlsList: string[], index?: number) => {
|
|
96
|
+
// 预览图片
|
|
97
|
+
const urls = urlsList.map((item: string) => {
|
|
98
|
+
if (item && item.indexOf('http') === -1) {
|
|
99
|
+
return baseUrl + item
|
|
100
|
+
} else {
|
|
101
|
+
return item
|
|
102
|
+
}
|
|
103
|
+
})
|
|
104
|
+
const uniqueValues = new Set(urls)
|
|
105
|
+
// 如果预览的图片地址相同,则直接预览,预览索引设置无效
|
|
106
|
+
if (uniqueValues.size === 1) {
|
|
107
|
+
uni.previewImage({
|
|
108
|
+
urls
|
|
109
|
+
})
|
|
110
|
+
} else {
|
|
111
|
+
uni.previewImage({
|
|
112
|
+
current: index,
|
|
113
|
+
urls
|
|
114
|
+
})
|
|
115
|
+
}
|
|
116
|
+
}
|
|
117
|
+
</script>
|
|
118
|
+
<template>
|
|
119
|
+
<view class="lx_upload_box flex-center-start wrap">
|
|
120
|
+
<view
|
|
121
|
+
v-if="limit === 1 && modelValue"
|
|
122
|
+
class="upload_item_box"
|
|
123
|
+
:style="{
|
|
124
|
+
width: boxWidth,
|
|
125
|
+
height: boxWidth,
|
|
126
|
+
borderRadius: radius
|
|
127
|
+
}"
|
|
128
|
+
>
|
|
129
|
+
<image :src="baseUrl + modelValue" mode="aspectFill" @click="previewImage([modelValue as string])"></image>
|
|
130
|
+
<view class="upload_close_icon flex" @click="uploadDel()">
|
|
131
|
+
<image :src="delIcon" mode="aspectFit" />
|
|
132
|
+
</view>
|
|
133
|
+
</view>
|
|
134
|
+
<view
|
|
135
|
+
v-else
|
|
136
|
+
class="upload_item_box"
|
|
137
|
+
:style="{
|
|
138
|
+
width: boxWidth,
|
|
139
|
+
height: boxWidth,
|
|
140
|
+
borderRadius: radius,
|
|
141
|
+
marginRight: (index + 1) % props.rowNum === 0 ? 0 : spacing + 'px',
|
|
142
|
+
marginBottom: spacing + 'px'
|
|
143
|
+
}"
|
|
144
|
+
v-for="(item, index) in modelValue"
|
|
145
|
+
:key="index"
|
|
146
|
+
>
|
|
147
|
+
<image :src="baseUrl + item" mode="aspectFill" @click="previewImage(modelValue as string[], index)"></image>
|
|
148
|
+
<view class="upload_close_icon flex" @click="uploadDel(index)">
|
|
149
|
+
<image :src="delIcon" mode="aspectFit" />
|
|
150
|
+
</view>
|
|
151
|
+
</view>
|
|
152
|
+
|
|
153
|
+
<view
|
|
154
|
+
v-if="modelValue.length < limit"
|
|
155
|
+
class="upload_add_box flex"
|
|
156
|
+
@click="uploadAdd"
|
|
157
|
+
:style="{ width: boxWidth, height: boxWidth, borderRadius: radius, marginBottom: spacing + 'px' }"
|
|
158
|
+
>
|
|
159
|
+
<view class="upload_add">
|
|
160
|
+
<image :src="addIcon" mode="aspectFit"></image>
|
|
161
|
+
</view>
|
|
162
|
+
</view>
|
|
163
|
+
</view>
|
|
164
|
+
</template>
|
|
165
|
+
<style lang="scss" scoped>
|
|
166
|
+
.lx_upload_box {
|
|
167
|
+
.upload_add_box {
|
|
168
|
+
background: rgba(240, 240, 240, 1);
|
|
169
|
+
.upload_add {
|
|
170
|
+
width: 36rpx;
|
|
171
|
+
height: 36rpx;
|
|
172
|
+
}
|
|
173
|
+
}
|
|
174
|
+
// 上传的图片
|
|
175
|
+
.upload_item_box {
|
|
176
|
+
overflow: hidden;
|
|
177
|
+
box-sizing: border-box;
|
|
178
|
+
position: relative;
|
|
179
|
+
.upload_close_icon {
|
|
180
|
+
background-color: rgba($color: #000000, $alpha: 0.3);
|
|
181
|
+
box-shadow: 0 0 8rpx 0 rgba(0, 0, 0, 0.5);
|
|
182
|
+
border-radius: 50%;
|
|
183
|
+
width: 28rpx;
|
|
184
|
+
height: 28rpx;
|
|
185
|
+
position: absolute;
|
|
186
|
+
top: 8rpx;
|
|
187
|
+
right: 8rpx;
|
|
188
|
+
z-index: 5;
|
|
189
|
+
}
|
|
190
|
+
}
|
|
191
|
+
}
|
|
192
|
+
</style>
|
package/index.ts
CHANGED
|
@@ -1,8 +1,15 @@
|
|
|
1
1
|
import type { App } from 'vue'
|
|
2
|
-
import
|
|
3
|
-
import
|
|
4
|
-
|
|
5
|
-
|
|
2
|
+
import lxHeader from './components/lx-header/lx-header.vue'
|
|
3
|
+
import lxHello from './components/lx-hello/lx-hello.vue'
|
|
4
|
+
import lxImage from './components/lx-image/lx-image.vue'
|
|
5
|
+
import lxList from './components/lx-list/lx-list.vue'
|
|
6
|
+
import lxListState from './components/lx-list-state/lx-list-state.vue'
|
|
7
|
+
import lxOperateBottom from './components/lx-operate-bottom/lx-operate-bottom.vue'
|
|
8
|
+
import lxSubmitBtn from './components/lx-submit-btn/lx-submit-btn.vue'
|
|
9
|
+
import lxUpload from './components/lx-upload/lx-upload.vue'
|
|
10
|
+
|
|
11
|
+
export { lxHello, lxImage, lxHeader, lxList, lxListState, lxOperateBottom, lxSubmitBtn, lxUpload }
|
|
12
|
+
const coms = [ lxHello, lxImage, lxHeader, lxList, lxListState, lxOperateBottom, lxSubmitBtn, lxUpload ]
|
|
6
13
|
export default {
|
|
7
14
|
install(app: App){
|
|
8
15
|
coms.forEach((commponent) => {
|