uview-pro 0.3.0 → 0.3.1
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/changelog.md +584 -574
- package/components/common/props.ts +22 -22
- package/components/u-action-sheet/types.ts +37 -37
- package/components/u-action-sheet/u-action-sheet.vue +178 -178
- package/components/u-alert-tips/types.ts +41 -41
- package/components/u-alert-tips/u-alert-tips.vue +238 -238
- package/components/u-avatar/types.ts +36 -36
- package/components/u-avatar/u-avatar.vue +217 -217
- package/components/u-avatar-cropper/types.ts +23 -23
- package/components/u-avatar-cropper/u-avatar-cropper.vue +297 -297
- package/components/u-avatar-cropper/weCropper.d.ts +62 -62
- package/components/u-avatar-cropper/weCropper.js +1281 -1281
- package/components/u-avatar-cropper/weCropper.ts +1276 -1276
- package/components/u-back-top/types.ts +36 -36
- package/components/u-back-top/u-back-top.vue +140 -140
- package/components/u-badge/types.ts +38 -38
- package/components/u-badge/u-badge.vue +183 -183
- package/components/u-button/types.ts +66 -66
- package/components/u-button/u-button.vue +579 -579
- package/components/u-calendar/types.ts +75 -75
- package/components/u-calendar/u-calendar.vue +793 -793
- package/components/u-car-keyboard/types.ts +14 -14
- package/components/u-car-keyboard/u-car-keyboard.vue +262 -262
- package/components/u-card/types.ts +61 -61
- package/components/u-card/u-card.vue +209 -209
- package/components/u-cell-group/types.ts +19 -19
- package/components/u-cell-group/u-cell-group.vue +60 -60
- package/components/u-cell-item/types.ts +56 -56
- package/components/u-cell-item/u-cell-item.vue +226 -226
- package/components/u-checkbox/types.ts +33 -33
- package/components/u-checkbox/u-checkbox.vue +282 -282
- package/components/u-checkbox-group/types.ts +34 -34
- package/components/u-checkbox-group/u-checkbox-group.vue +130 -130
- package/components/u-circle-progress/types.ts +54 -54
- package/components/u-circle-progress/u-circle-progress.vue +206 -206
- package/components/u-city-select/types.ts +22 -22
- package/components/u-city-select/u-city-select.vue +276 -276
- package/components/u-col/types.ts +32 -32
- package/components/u-col/u-col.vue +142 -142
- package/components/u-collapse/types.ts +33 -33
- package/components/u-collapse/u-collapse.vue +190 -190
- package/components/u-collapse-item/types.ts +27 -27
- package/components/u-collapse-item/u-collapse-item.vue +290 -290
- package/components/u-column-notice/types.ts +50 -50
- package/components/u-column-notice/u-column-notice.vue +222 -222
- package/components/u-count-down/types.ts +44 -44
- package/components/u-count-down/u-count-down.vue +286 -286
- package/components/u-count-to/types.ts +34 -34
- package/components/u-count-to/u-count-to.vue +266 -266
- package/components/u-divider/types.ts +33 -33
- package/components/u-divider/u-divider.vue +145 -145
- package/components/u-dropdown/types.ts +34 -34
- package/components/u-dropdown/u-dropdown.vue +330 -330
- package/components/u-dropdown-item/types.ts +29 -29
- package/components/u-dropdown-item/u-dropdown-item.vue +120 -120
- package/components/u-empty/types.ts +38 -38
- package/components/u-empty/u-empty.vue +103 -103
- package/components/u-field/types.ts +71 -71
- package/components/u-field/u-field.vue +388 -388
- package/components/u-form/types.ts +29 -29
- package/components/u-form/u-form.vue +130 -130
- package/components/u-form-item/types.ts +72 -72
- package/components/u-form-item/u-form-item.vue +447 -447
- package/components/u-full-screen/types.ts +16 -16
- package/components/u-full-screen/u-full-screen.vue +103 -103
- package/components/u-gap/types.ts +20 -20
- package/components/u-gap/u-gap.vue +50 -50
- package/components/u-grid/types.ts +21 -21
- package/components/u-grid/u-grid.vue +91 -91
- package/components/u-grid-item/types.ts +16 -16
- package/components/u-grid-item/u-grid-item.vue +130 -130
- package/components/u-icon/types.ts +61 -61
- package/components/u-icon/u-icon.vue +296 -296
- package/components/u-image/types.ts +51 -51
- package/components/u-image/u-image.vue +239 -239
- package/components/u-index-anchor/types.ts +16 -16
- package/components/u-index-anchor/u-index-anchor.vue +94 -94
- package/components/u-index-list/types.ts +43 -43
- package/components/u-index-list/u-index-list.vue +352 -352
- package/components/u-input/types.ts +137 -137
- package/components/u-input/u-input.vue +288 -288
- package/components/u-keyboard/types.ts +40 -40
- package/components/u-keyboard/u-keyboard.vue +178 -178
- package/components/u-lazy-load/types.ts +37 -37
- package/components/u-lazy-load/u-lazy-load.vue +246 -246
- package/components/u-line/types.ts +44 -44
- package/components/u-line/u-line.vue +68 -68
- package/components/u-line-progress/types.ts +58 -58
- package/components/u-line-progress/u-line-progress.vue +126 -126
- package/components/u-link/types.ts +43 -43
- package/components/u-link/u-link.vue +84 -84
- package/components/u-loading/types.ts +35 -35
- package/components/u-loading/u-loading.vue +105 -105
- package/components/u-loading-popup/types.ts +26 -26
- package/components/u-loading-popup/u-loading-popup.vue +253 -253
- package/components/u-loadmore/types.ts +79 -79
- package/components/u-loadmore/u-loadmore.vue +156 -156
- package/components/u-mask/types.ts +40 -40
- package/components/u-mask/u-mask.vue +113 -113
- package/components/u-message-input/types.ts +74 -74
- package/components/u-message-input/u-message-input.vue +281 -281
- package/components/u-modal/types.ts +118 -118
- package/components/u-modal/u-modal.vue +220 -220
- package/components/u-navbar/types.ts +103 -103
- package/components/u-navbar/u-navbar.vue +251 -251
- package/components/u-no-network/image.ts +2 -2
- package/components/u-no-network/types.ts +28 -28
- package/components/u-no-network/u-no-network.vue +303 -303
- package/components/u-notice-bar/types.ts +111 -111
- package/components/u-notice-bar/u-notice-bar.vue +189 -189
- package/components/u-number-box/types.ts +42 -42
- package/components/u-number-box/u-number-box.vue +321 -321
- package/components/u-number-keyboard/types.ts +26 -26
- package/components/u-number-keyboard/u-number-keyboard.vue +188 -188
- package/components/u-picker/types.ts +123 -123
- package/components/u-picker/u-picker.vue +685 -685
- package/components/u-popup/types.ts +59 -59
- package/components/u-popup/u-popup.vue +385 -385
- package/components/u-radio/types.ts +27 -27
- package/components/u-radio/u-radio.vue +279 -279
- package/components/u-radio-group/types.ts +31 -31
- package/components/u-radio-group/u-radio-group.vue +96 -96
- package/components/u-rate/types.ts +42 -42
- package/components/u-rate/u-rate.vue +249 -249
- package/components/u-read-more/types.ts +37 -37
- package/components/u-read-more/u-read-more.vue +172 -172
- package/components/u-root-portal/u-root-portal.vue +56 -56
- package/components/u-row/types.ts +22 -22
- package/components/u-row/u-row.vue +105 -105
- package/components/u-row-notice/types.ts +41 -41
- package/components/u-row-notice/u-row-notice.vue +256 -256
- package/components/u-safe-bottom/u-safe-bottom.vue +57 -57
- package/components/u-search/types.ts +55 -55
- package/components/u-search/u-search.vue +279 -279
- package/components/u-section/types.ts +34 -34
- package/components/u-section/u-section.vue +150 -150
- package/components/u-select/types.ts +45 -45
- package/components/u-select/u-select.vue +388 -388
- package/components/u-skeleton/types.ts +22 -22
- package/components/u-skeleton/u-skeleton.vue +231 -231
- package/components/u-slider/types.ts +34 -34
- package/components/u-slider/u-slider.vue +255 -255
- package/components/u-status-bar/u-status-bar.vue +74 -74
- package/components/u-steps/types.ts +30 -30
- package/components/u-steps/u-steps.vue +181 -181
- package/components/u-sticky/types.ts +24 -24
- package/components/u-sticky/u-sticky.vue +178 -178
- package/components/u-subsection/types.ts +38 -38
- package/components/u-subsection/u-subsection.vue +339 -339
- package/components/u-swipe-action/types.ts +52 -52
- package/components/u-swipe-action/u-swipe-action.vue +276 -276
- package/components/u-swiper/types.ts +49 -49
- package/components/u-swiper/u-swiper.vue +308 -308
- package/components/u-switch/types.ts +30 -30
- package/components/u-switch/u-switch.vue +150 -150
- package/components/u-tabbar/types.ts +38 -38
- package/components/u-tabbar/u-tabbar.vue +315 -315
- package/components/u-table/types.ts +27 -27
- package/components/u-table/u-table.vue +67 -67
- package/components/u-tabs/types.ts +53 -53
- package/components/u-tabs/u-tabs.vue +302 -302
- package/components/u-tabs-swiper/types.ts +55 -55
- package/components/u-tabs-swiper/u-tabs-swiper.vue +409 -409
- package/components/u-tag/types.ts +39 -39
- package/components/u-tag/u-tag.vue +268 -268
- package/components/u-td/types.ts +14 -14
- package/components/u-td/u-td.vue +98 -98
- package/components/u-text/types.ts +72 -72
- package/components/u-text/u-text.vue +343 -343
- package/components/u-th/types.ts +14 -14
- package/components/u-th/u-th.vue +92 -92
- package/components/u-time-line/u-time-line.vue +53 -53
- package/components/u-time-line-item/types.ts +16 -16
- package/components/u-time-line-item/u-time-line-item.vue +90 -90
- package/components/u-toast/types.ts +38 -38
- package/components/u-toast/u-toast.vue +240 -240
- package/components/u-top-tips/types.ts +16 -16
- package/components/u-top-tips/u-top-tips.vue +130 -130
- package/components/u-tr/types.ts +11 -11
- package/components/u-tr/u-tr.vue +39 -39
- package/components/u-upload/types.ts +82 -82
- package/components/u-upload/u-upload.vue +568 -568
- package/components/u-verification-code/types.ts +24 -24
- package/components/u-verification-code/u-verification-code.vue +176 -176
- package/components/u-waterfall/types.ts +18 -18
- package/components/u-waterfall/u-waterfall.vue +187 -187
- package/iconfont.css +913 -913
- package/index.scss +25 -25
- package/index.ts +38 -38
- package/libs/config/config.ts +26 -26
- package/libs/config/zIndex.ts +37 -37
- package/libs/css/color.scss +155 -155
- package/libs/css/common.scss +178 -178
- package/libs/css/style.components.scss +16 -16
- package/libs/css/style.h5.scss +8 -8
- package/libs/css/style.mp.scss +72 -72
- package/libs/css/style.nvue.scss +15 -15
- package/libs/css/style.vue.scss +188 -188
- package/libs/function/$parent.ts +24 -24
- package/libs/function/addUnit.ts +13 -13
- package/libs/function/color.ts +37 -37
- package/libs/function/colorGradient.ts +139 -139
- package/libs/function/debounce.ts +28 -28
- package/libs/function/deepClone.ts +39 -39
- package/libs/function/deepMerge.ts +35 -35
- package/libs/function/getParent.ts +63 -63
- package/libs/function/getRect.ts +26 -26
- package/libs/function/guid.ts +42 -42
- package/libs/function/md5.ts +403 -403
- package/libs/function/parent.ts +21 -21
- package/libs/function/queryParams.ts +64 -64
- package/libs/function/random.ts +16 -16
- package/libs/function/randomArray.ts +11 -11
- package/libs/function/route.ts +118 -118
- package/libs/function/styleUtils.ts +83 -83
- package/libs/function/sys.ts +15 -15
- package/libs/function/test.ts +289 -289
- package/libs/function/throttle.ts +31 -31
- package/libs/function/timeFormat.ts +55 -55
- package/libs/function/timeFrom.ts +48 -48
- package/libs/function/toast.ts +14 -14
- package/libs/function/trim.ts +21 -21
- package/libs/function/type2icon.ts +39 -39
- package/libs/hooks/index.ts +4 -4
- package/libs/hooks/useCompRelation.ts +364 -364
- package/libs/hooks/useComponent.ts +759 -759
- package/libs/hooks/useEmitter.ts +79 -79
- package/libs/hooks/useParent.ts +33 -33
- package/libs/hooks/useRect.ts +33 -33
- package/libs/index.ts +337 -337
- package/libs/request/auto-http.ts +76 -76
- package/libs/request/index.ts +242 -242
- package/libs/store/index.ts +88 -88
- package/libs/util/async-validator.d.ts +75 -75
- package/libs/util/async-validator.js +1 -1
- package/libs/util/calendar.d.ts +57 -57
- package/libs/util/emitter.ts +112 -112
- package/libs/util/eventBus.ts +86 -86
- package/libs/util/logger.ts +364 -364
- package/libs/util/mitt.ts +118 -118
- package/libs/util/parent.ts +20 -20
- package/package.json +4 -4
- package/readme.md +241 -241
- package/theme.scss +38 -38
- package/types/components.d.ts +97 -97
- package/types/global.d.ts +331 -331
- package/types/ignore-errors.d.ts +30 -30
- package/types/index.d.ts +19 -19
- package/types/uni-app.d.ts +63 -63
package/libs/hooks/useEmitter.ts
CHANGED
|
@@ -1,79 +1,79 @@
|
|
|
1
|
-
import { type ComponentInternalInstance, getCurrentInstance } from 'vue';
|
|
2
|
-
|
|
3
|
-
/**
|
|
4
|
-
* 将事件名转换为驼峰格式
|
|
5
|
-
* @param str 需要转换的字符串
|
|
6
|
-
* @description 例如:on-form-change -> onFormChange
|
|
7
|
-
* @returns
|
|
8
|
-
*/
|
|
9
|
-
function formatToCamelCase(str: string): string {
|
|
10
|
-
return str.replace(/-([a-z])/g, function (g) {
|
|
11
|
-
return g[1].toUpperCase();
|
|
12
|
-
});
|
|
13
|
-
}
|
|
14
|
-
|
|
15
|
-
export function useEmitter(name: string) {
|
|
16
|
-
const instance: ComponentInternalInstance | null | undefined = getCurrentInstance();
|
|
17
|
-
|
|
18
|
-
/** * 向上查找父组件并派发事件
|
|
19
|
-
* @param instance 当前组件实例(setup中可用getCurrentInstance())
|
|
20
|
-
* @param componentName 目标组件名
|
|
21
|
-
* @param eventName 事件名
|
|
22
|
-
* @param params 参数
|
|
23
|
-
*/
|
|
24
|
-
function dispatch(componentName: string, eventName: string, ...params: any[]) {
|
|
25
|
-
let parent = instance && (instance.parent as ComponentInternalInstance | null | undefined);
|
|
26
|
-
while (parent) {
|
|
27
|
-
const name = (parent.type as any)?.name as string | undefined;
|
|
28
|
-
if (name === componentName) {
|
|
29
|
-
// 找到目标组件,派发事件
|
|
30
|
-
// Vue3未解决,目标组件事件监听失效,待优化,暂时使用下面的方式解决,如果你有好的方式也可以告诉我或者提PR
|
|
31
|
-
parent.emit && parent.emit(eventName, ...params);
|
|
32
|
-
// 如果有对应的方法,执行方法
|
|
33
|
-
// 这里可以考虑将 eventName 转换为驼峰格式
|
|
34
|
-
// 例如:on-form-change -> onFormChange
|
|
35
|
-
parent.exposed?.[formatToCamelCase(eventName)] &&
|
|
36
|
-
parent.exposed[formatToCamelCase(eventName)](...params);
|
|
37
|
-
break;
|
|
38
|
-
}
|
|
39
|
-
parent = parent.parent;
|
|
40
|
-
}
|
|
41
|
-
}
|
|
42
|
-
|
|
43
|
-
/**
|
|
44
|
-
* 向下递归查找子组件并广播事件
|
|
45
|
-
* @param instance 当前组件实例(setup中可用getCurrentInstance())
|
|
46
|
-
* @param componentName 目标组件名
|
|
47
|
-
* @param eventName 事件名
|
|
48
|
-
* @param params 参数
|
|
49
|
-
*/
|
|
50
|
-
function broadcast(componentName: string, eventName: string, ...params: any[]) {
|
|
51
|
-
if (!instance) return;
|
|
52
|
-
const subTree = (instance.subTree as any)?.children || [];
|
|
53
|
-
const children = Array.isArray(subTree) ? subTree : [subTree];
|
|
54
|
-
children.forEach((vnode: any) => {
|
|
55
|
-
const child = vnode.component as ComponentInternalInstance | undefined;
|
|
56
|
-
|
|
57
|
-
if (child) {
|
|
58
|
-
const name = (child.type as any)?.name as string | undefined;
|
|
59
|
-
if (name === componentName) {
|
|
60
|
-
// 找到目标组件,广播事件
|
|
61
|
-
// Vue3未解决,目标组件事件监听失效,待优化,暂时使用下面的方式解决,如果你有好的方式也可以告诉我或者提PR
|
|
62
|
-
child.emit && child.emit(eventName, ...params);
|
|
63
|
-
// 如果有对应的方法,执行方法
|
|
64
|
-
// 这里可以考虑将 eventName 转换为驼峰格式
|
|
65
|
-
// 例如:on-form-change -> onFormChange
|
|
66
|
-
child.exposed?.[formatToCamelCase(eventName)] &&
|
|
67
|
-
child.exposed[formatToCamelCase(eventName)](...params);
|
|
68
|
-
} else {
|
|
69
|
-
broadcast.call(child, componentName, eventName, ...params);
|
|
70
|
-
}
|
|
71
|
-
}
|
|
72
|
-
});
|
|
73
|
-
}
|
|
74
|
-
|
|
75
|
-
return {
|
|
76
|
-
dispatch,
|
|
77
|
-
broadcast
|
|
78
|
-
};
|
|
79
|
-
}
|
|
1
|
+
import { type ComponentInternalInstance, getCurrentInstance } from 'vue';
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* 将事件名转换为驼峰格式
|
|
5
|
+
* @param str 需要转换的字符串
|
|
6
|
+
* @description 例如:on-form-change -> onFormChange
|
|
7
|
+
* @returns
|
|
8
|
+
*/
|
|
9
|
+
function formatToCamelCase(str: string): string {
|
|
10
|
+
return str.replace(/-([a-z])/g, function (g) {
|
|
11
|
+
return g[1].toUpperCase();
|
|
12
|
+
});
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
export function useEmitter(name: string) {
|
|
16
|
+
const instance: ComponentInternalInstance | null | undefined = getCurrentInstance();
|
|
17
|
+
|
|
18
|
+
/** * 向上查找父组件并派发事件
|
|
19
|
+
* @param instance 当前组件实例(setup中可用getCurrentInstance())
|
|
20
|
+
* @param componentName 目标组件名
|
|
21
|
+
* @param eventName 事件名
|
|
22
|
+
* @param params 参数
|
|
23
|
+
*/
|
|
24
|
+
function dispatch(componentName: string, eventName: string, ...params: any[]) {
|
|
25
|
+
let parent = instance && (instance.parent as ComponentInternalInstance | null | undefined);
|
|
26
|
+
while (parent) {
|
|
27
|
+
const name = (parent.type as any)?.name as string | undefined;
|
|
28
|
+
if (name === componentName) {
|
|
29
|
+
// 找到目标组件,派发事件
|
|
30
|
+
// Vue3未解决,目标组件事件监听失效,待优化,暂时使用下面的方式解决,如果你有好的方式也可以告诉我或者提PR
|
|
31
|
+
parent.emit && parent.emit(eventName, ...params);
|
|
32
|
+
// 如果有对应的方法,执行方法
|
|
33
|
+
// 这里可以考虑将 eventName 转换为驼峰格式
|
|
34
|
+
// 例如:on-form-change -> onFormChange
|
|
35
|
+
parent.exposed?.[formatToCamelCase(eventName)] &&
|
|
36
|
+
parent.exposed[formatToCamelCase(eventName)](...params);
|
|
37
|
+
break;
|
|
38
|
+
}
|
|
39
|
+
parent = parent.parent;
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
/**
|
|
44
|
+
* 向下递归查找子组件并广播事件
|
|
45
|
+
* @param instance 当前组件实例(setup中可用getCurrentInstance())
|
|
46
|
+
* @param componentName 目标组件名
|
|
47
|
+
* @param eventName 事件名
|
|
48
|
+
* @param params 参数
|
|
49
|
+
*/
|
|
50
|
+
function broadcast(componentName: string, eventName: string, ...params: any[]) {
|
|
51
|
+
if (!instance) return;
|
|
52
|
+
const subTree = (instance.subTree as any)?.children || [];
|
|
53
|
+
const children = Array.isArray(subTree) ? subTree : [subTree];
|
|
54
|
+
children.forEach((vnode: any) => {
|
|
55
|
+
const child = vnode.component as ComponentInternalInstance | undefined;
|
|
56
|
+
|
|
57
|
+
if (child) {
|
|
58
|
+
const name = (child.type as any)?.name as string | undefined;
|
|
59
|
+
if (name === componentName) {
|
|
60
|
+
// 找到目标组件,广播事件
|
|
61
|
+
// Vue3未解决,目标组件事件监听失效,待优化,暂时使用下面的方式解决,如果你有好的方式也可以告诉我或者提PR
|
|
62
|
+
child.emit && child.emit(eventName, ...params);
|
|
63
|
+
// 如果有对应的方法,执行方法
|
|
64
|
+
// 这里可以考虑将 eventName 转换为驼峰格式
|
|
65
|
+
// 例如:on-form-change -> onFormChange
|
|
66
|
+
child.exposed?.[formatToCamelCase(eventName)] &&
|
|
67
|
+
child.exposed[formatToCamelCase(eventName)](...params);
|
|
68
|
+
} else {
|
|
69
|
+
broadcast.call(child, componentName, eventName, ...params);
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
});
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
return {
|
|
76
|
+
dispatch,
|
|
77
|
+
broadcast
|
|
78
|
+
};
|
|
79
|
+
}
|
package/libs/hooks/useParent.ts
CHANGED
|
@@ -1,33 +1,33 @@
|
|
|
1
|
-
import { getCurrentInstance, onUnmounted } from 'vue';
|
|
2
|
-
|
|
3
|
-
export function useParent(name: string) {
|
|
4
|
-
const instance = getCurrentInstance();
|
|
5
|
-
|
|
6
|
-
function getParent() {
|
|
7
|
-
if (!instance) return null;
|
|
8
|
-
|
|
9
|
-
// 查找父组件
|
|
10
|
-
let parent: any = instance.parent;
|
|
11
|
-
while (parent) {
|
|
12
|
-
const parentName = parent.type?.name;
|
|
13
|
-
if (parentName === name) break;
|
|
14
|
-
parent = parent.parent;
|
|
15
|
-
}
|
|
16
|
-
|
|
17
|
-
// 建立父子关系
|
|
18
|
-
if (parent) {
|
|
19
|
-
(parent as any).children = (parent as any).children || [];
|
|
20
|
-
(parent as any).children.push(instance);
|
|
21
|
-
// 卸载时移除
|
|
22
|
-
onUnmounted(() => {
|
|
23
|
-
const i = parent.children.indexOf(instance);
|
|
24
|
-
i > -1 && parent.children.splice(i, 1);
|
|
25
|
-
});
|
|
26
|
-
}
|
|
27
|
-
return parent;
|
|
28
|
-
}
|
|
29
|
-
|
|
30
|
-
return {
|
|
31
|
-
getParent
|
|
32
|
-
};
|
|
33
|
-
}
|
|
1
|
+
import { getCurrentInstance, onUnmounted } from 'vue';
|
|
2
|
+
|
|
3
|
+
export function useParent(name: string) {
|
|
4
|
+
const instance = getCurrentInstance();
|
|
5
|
+
|
|
6
|
+
function getParent() {
|
|
7
|
+
if (!instance) return null;
|
|
8
|
+
|
|
9
|
+
// 查找父组件
|
|
10
|
+
let parent: any = instance.parent;
|
|
11
|
+
while (parent) {
|
|
12
|
+
const parentName = parent.type?.name;
|
|
13
|
+
if (parentName === name) break;
|
|
14
|
+
parent = parent.parent;
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
// 建立父子关系
|
|
18
|
+
if (parent) {
|
|
19
|
+
(parent as any).children = (parent as any).children || [];
|
|
20
|
+
(parent as any).children.push(instance);
|
|
21
|
+
// 卸载时移除
|
|
22
|
+
onUnmounted(() => {
|
|
23
|
+
const i = parent.children.indexOf(instance);
|
|
24
|
+
i > -1 && parent.children.splice(i, 1);
|
|
25
|
+
});
|
|
26
|
+
}
|
|
27
|
+
return parent;
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
return {
|
|
31
|
+
getParent
|
|
32
|
+
};
|
|
33
|
+
}
|
package/libs/hooks/useRect.ts
CHANGED
|
@@ -1,33 +1,33 @@
|
|
|
1
|
-
import { getCurrentInstance, nextTick, ref } from 'vue';
|
|
2
|
-
|
|
3
|
-
/**
|
|
4
|
-
* useRect - 获取元素的位置信息(响应式,原生实现)
|
|
5
|
-
* @param selector 选择器(如 #id 或 .class)
|
|
6
|
-
* @param all 是否获取所有匹配元素
|
|
7
|
-
* @returns rect 响应式的节点信息,refresh 主动刷新方法
|
|
8
|
-
*/
|
|
9
|
-
export function useRect(selector: string, all = false) {
|
|
10
|
-
const rect = ref<any>(all ? [] : null);
|
|
11
|
-
const instance = getCurrentInstance();
|
|
12
|
-
|
|
13
|
-
async function refreshRect(delay = 0) {
|
|
14
|
-
await nextTick();
|
|
15
|
-
return new Promise(resolve => {
|
|
16
|
-
setTimeout(() => {
|
|
17
|
-
uni.createSelectorQuery()
|
|
18
|
-
.in(instance?.proxy)
|
|
19
|
-
[all ? 'selectAll' : 'select'](selector)
|
|
20
|
-
.boundingClientRect((res: any) => {
|
|
21
|
-
rect.value = res;
|
|
22
|
-
resolve(res);
|
|
23
|
-
})
|
|
24
|
-
.exec();
|
|
25
|
-
}, delay);
|
|
26
|
-
});
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
return {
|
|
30
|
-
rect,
|
|
31
|
-
refreshRect
|
|
32
|
-
};
|
|
33
|
-
}
|
|
1
|
+
import { getCurrentInstance, nextTick, ref } from 'vue';
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* useRect - 获取元素的位置信息(响应式,原生实现)
|
|
5
|
+
* @param selector 选择器(如 #id 或 .class)
|
|
6
|
+
* @param all 是否获取所有匹配元素
|
|
7
|
+
* @returns rect 响应式的节点信息,refresh 主动刷新方法
|
|
8
|
+
*/
|
|
9
|
+
export function useRect(selector: string, all = false) {
|
|
10
|
+
const rect = ref<any>(all ? [] : null);
|
|
11
|
+
const instance = getCurrentInstance();
|
|
12
|
+
|
|
13
|
+
async function refreshRect(delay = 0) {
|
|
14
|
+
await nextTick();
|
|
15
|
+
return new Promise(resolve => {
|
|
16
|
+
setTimeout(() => {
|
|
17
|
+
uni.createSelectorQuery()
|
|
18
|
+
.in(instance?.proxy)
|
|
19
|
+
[all ? 'selectAll' : 'select'](selector)
|
|
20
|
+
.boundingClientRect((res: any) => {
|
|
21
|
+
rect.value = res;
|
|
22
|
+
resolve(res);
|
|
23
|
+
})
|
|
24
|
+
.exec();
|
|
25
|
+
}, delay);
|
|
26
|
+
});
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
return {
|
|
30
|
+
rect,
|
|
31
|
+
refreshRect
|
|
32
|
+
};
|
|
33
|
+
}
|