diff --git a/src/components/image/index.tsx b/src/components/image/index.tsx index 5aafa2e..d982530 100644 --- a/src/components/image/index.tsx +++ b/src/components/image/index.tsx @@ -1,11 +1,38 @@ -import { useMemo } from "react"; -import { useEffect, useState, memo } from "react"; -import { getImageSize, getResizeHeight, fallbackUrl, ImageSize } from "./tool"; +import { useMemo, useState } from "react"; +import { + getImageSize, + getResizeHeight, + fallbackUrl as DefaultFallbackUrl, + ImageSize, +} from "./tool"; +/** + * @description Image组件参数 + */ type ImageProps = { + /** + * @description 图片的url + * @example "www.example.com/1.jpg" + */ url: string; + /** + * @description 图片失效的兜底图片url + * @example "www.example.com/fallback.jpg" + * 建议提供base64版本 + */ + fallbackUrl?: string; + /** + * @description 图片默认宽度,因为自适应的原因最终效果可能大于该宽度 + * @default 180 + * @example 180 + */ + width?: number; }; +/** + * @description 图片预加载hook + */ + function useLoading(url: string) { const [obj, setObj] = useState({ width: 0, @@ -25,16 +52,25 @@ function useLoading(url: string) { return obj; } -export default function Image({ url }: ImageProps) { +/** + *@description 图片组件库,默认支持图片加载fallback。 + */ + +export default function Image({ + url, + width = 180, + fallbackUrl = DefaultFallbackUrl, +}: ImageProps) { const res = useLoading(url), - { isLoaded, success } = res; - // console.log(res); + { isLoaded, success } = res, + real_width = width || 180, + real_fallback_url = fallbackUrl || DefaultFallbackUrl; return (
{ return new Promise((resolve, reject) => { @@ -39,6 +43,10 @@ export function getImageSize(imageSrc: string): Promise { }); } +/** + * @description 获取图片经过缩略的大小,默认提供fallback处理。返回数字为5的整数倍。 + */ + export function getResizeHeight(imageSizeObj: ImageSize, realwidth: number) { const res = Math.ceil((100 + Math.ceil(Math.random() * 100)) / 5) * 5; if ( @@ -53,5 +61,8 @@ export function getResizeHeight(imageSizeObj: ImageSize, realwidth: number) { return isNaN(realheight) ? res : Math.ceil(realheight / 5) * 5; } +/** + * @description 图片加载失败的fallback图片,已经过base64处理。 + */ export const fallbackUrl = "";