types(@vant/use): improve Ref param typing

This commit is contained in:
chenjiahan 2020-10-09 20:32:31 +08:00
parent 767ca80499
commit 14d2826cc7
6 changed files with 10 additions and 8 deletions

View File

@ -60,7 +60,7 @@ export default {
```ts
function useClickAway(
target: Element | Ref<Element>,
target: Element | Ref<Element | undefined>,
listener: EventListener,
options?: Options
): void;

View File

@ -7,7 +7,7 @@ export type UseClickAwayOptions = {
};
export function useClickAway(
target: Element | Ref<Element>,
target: Element | Ref<Element | undefined>,
listener: EventListener,
options: UseClickAwayOptions = {}
) {
@ -19,7 +19,7 @@ export function useClickAway(
const onClick = (event: Event) => {
const element = unref(target);
if (!element.contains(event.target as Node)) {
if (element && !element.contains(event.target as Node)) {
listener(event);
}
};

View File

@ -31,7 +31,7 @@ export default {
### 类型定义
```ts
function useRect((Element | Window) | Ref<Element | Window>): DOMRect;
function useRect((Element | Window) | Ref<Element | Window | undefined>): DOMRect;
```
### 返回值

View File

@ -5,7 +5,7 @@ function isWindow(val: unknown): val is Window {
}
export const useRect = (
elementRef: (Element | Window) | Ref<Element | Window>
elementRef: (Element | Window) | Ref<Element | Window | undefined>
) => {
const element = unref(elementRef);
@ -23,7 +23,7 @@ export const useRect = (
};
}
if (element.getBoundingClientRect) {
if (element && element.getBoundingClientRect) {
return element.getBoundingClientRect();
}

View File

@ -37,7 +37,9 @@ export default {
### 类型定义
```ts
function useScrollParent(element: Ref<Element>): Ref<Element>;
function useScrollParent(
element: Ref<Element | undefined>
): Ref<Element | Window | undefined>;
```
### 参数

View File

@ -39,7 +39,7 @@ function getScrollParent(el: Element, root: ScrollElement = window) {
}
export function useScrollParent(el: Ref<Element | undefined>) {
const scrollParent = ref();
const scrollParent = ref<Element | Window>();
onMounted(() => {
if (el.value) {