viewer-utils 图片预览工具库

viewer-utils 图片预览工具库

一个基于 viewerjs 封装的轻量级图片预览库,支持多种输入格式,开箱即用,并针对现代前端开发进行了 Tree Shaking 优化。

支持以下特性:

  • 单图预览:支持直接传入 URL、事件对象或 DOM 元素
  • 列表预览:支持字符串数组或对象数组,自动识别数据格式
  • 本地预览 :支持 File 对象预览(如文件上传前的预览)
  • 自动清理:预览关闭后自动销毁实例并移除临时 DOM 节点
  • TypeScript:完善的类型定义支持

安装

你可以通过 npm 安装该库:

bash 复制代码
pnpm install @giszhc/viewer-utils

使用方法

previewSingle(source: string | Event | HTMLImageElement): void

预览单张图片。支持传入图片 URL 字符串、点击事件对象或直接传入图片 DOM 元素。

ts 复制代码
import { previewSingle } from '@giszhc/viewer-utils';
import "@giszhc/viewer-utils/dist/viewer-utils.css"

// 方式 1: 传入 URL
previewSingle('https://example.com/photo.jpg');

// 方式 2: 在点击事件中使用
const handleClick = (e: MouseEvent) => {
    previewSingle(e);
};

previewList(imgList: (string | IImageItem)[], index: number = 0): void

预览图片列表。支持纯地址数组或带信息的对象数组。

ts 复制代码
import { previewList } from '@giszhc/viewer-utils';
import "@giszhc/viewer-utils/dist/viewer-utils.css"

const images = [
    'https://example.com/1.jpg',
    { name: '图片2', url: 'https://example.com/2.jpg', thumb: 'https://example.com/2_thumb.jpg' }
];

// 预览并定位到第二张图
previewList(images, 1);

previewFiles(fileList: File[], index: number = 0): void

预览 File 对象数组。通常用于表单上传前的文件预览,内部会自动处理 Blob URL 的生成。

ts 复制代码
import { previewFiles } from '@giszhc/viewer-utils';
import "@giszhc/viewer-utils/dist/viewer-utils.css"

const input = document.querySelector('input[type="file"]');
input.addEventListener('change', (e) => {
    const files = Array.from(e.target.files);
    previewFiles(files);
});

previewPicture(imgList: IImageItem[], index: number = 0): void

核心预览方法。接收标准化的对象数组,提供最完整的自定义能力。

ts 复制代码
import { previewPicture, type IImageItem } from '@giszhc/viewer-utils';
import "@giszhc/viewer-utils/dist/viewer-utils.css"

const items: IImageItem[] = [
    { name: '风景', url: 'full.jpg', thumb: 'thumb.jpg' }
];
previewPicture(items, 0);

接口定义

ts 复制代码
interface IImageItem {
    name: string;   // 图片名称(预览时显示的标题)
    url: string;    // 高清图地址(data-original)
    thumb: string;  // 缩略图地址(src)
}

样式自定义

库会默认注入一些基础样式(如背景毛玻璃效果)。如果你需要覆盖样式,可以针对以下类名编写 CSS:

  • .viewer-backdrop: 背景遮罩
  • .viewer-toolbar: 工具栏样式

完结,撒花✿✿ヽ(°▽°)ノ✿

相关推荐
摘星编程2 小时前
React Native鸿蒙:Image本地图片显示
javascript·react native·react.js
爱上妖精的尾巴3 小时前
8-5 WPS JS宏 match、search、replace、split支持正则表达式的字符串函数
开发语言·前端·javascript·wps·jsa
小温冲冲3 小时前
通俗且全面精讲单例设计模式
开发语言·javascript·设计模式
意法半导体STM323 小时前
【官方原创】FDCAN数据段波特率增加后发送失败的问题分析 LAT1617
javascript·网络·stm32·单片机·嵌入式硬件·安全
咔咔一顿操作4 小时前
轻量无依赖!autoviwe 页面自适应组件实战:从安装到源码深度解析
javascript·arcgis·npm·css3·html5
刘联其4 小时前
.net也可以用Electron开发跨平台的桌面程序了
前端·javascript·electron
韩曙亮4 小时前
【jQuery】jQuery 选择器 ④ ( jQuery 筛选方法 | 方法分类场景 - 向下找后代、向上找祖先、同级找兄弟、范围限定查找 )
前端·javascript·jquery·jquery筛选方法
pas1364 小时前
42-mini-vue 实现 transform 功能
前端·javascript·vue.js
HetFrame4 小时前
一种纯前端实现 Markdown 内容即时分享的思路
html·react·链接·markdown·工具