npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

react-zmage

v0.8.5-beta.37

Published

A scalable image container

Downloads

2,817

Readme

GitHub license PRs Welcome

react-zmage 是一个基于 React 的的图片缩放控件, 使用 Zmage 标签包裹后的图片可以获得缩放效果, 您可以用这个控件替代原生的 img 标签, 令其附带图片缩放功能

需 react 版本大于 v16.6.0

在线

https://zmage.caldis.me

本地

git clone https://github.com/Caldis/react-zmage
cd react-zmage
npm i
npm run dev
npm i react-zmage --save

1.引入组件

import Zmage from 'react-zmage'

2.将页面中的 img 标签替换为 Zmage 组件

<img src="图片源连接"/>
👆 to 👇
<Zmage src="图片源连接"/>

也可以通过函数调用来唤出图片

// Zmage.browsing 函数接受的参数与 <Zmage/> 组件完全一致
<a onClick={() => Zmage.browsing({ src:imagePath })}>任意元素</a>

typescript中使用

import ReactZmage from 'react-zmage';

// 在生命周期等方法中使用
public componentDidMount() {
    const zmage = new ReactZmage({
        // ...options
    });
}

// 也支持组件方式使用
public render(): JSX.Element {
    const defaultConfig = {
        src: 'http://zmage.caldis.me/imgSet/childsDream/demo.jpg',
        alt: '示例图片',
    };

    return (
        <ReactZmage
            {...defaultConfig}
        />
    );
}

在线示例, 请参见 https://zmage.caldis.me

  • 基础调用属性

|配置项|类型|默认值|描述|示例| |:--:|:--:|:-----:|:----------|:----------:| | src | String | "" | 图片 Url,与 img 标签的 src 属性相同 | 示例 | | alt | String | "" | 图片占位文字,与 img 标签的 alt 属性相同 | 示例 | | set | Object[] | [] | 序列图片, 可以在 set 中传入多个图片对象用于在查看模式下呈现多张图片,也可用于呈现放大后的高清图片 | 示例 | | defaultPage | Number | 0 | 如果传入了set来展示多张图片, 可以用于指定打开后的默认页 | 示例 |

  • 预设配置 (beta)

|配置项|类型|默认值|描述|示例| |:--:|:--:|:-----:|:----------|:----------:| | preset | String | "auto" | 轻松配置界面的功能及样式, 可设置为 auto desktop mobile | 示例 受影响的配置项 |

  • 受控属性

|配置项|类型|默认值|描述|示例| |:--:|:--:|:-----:|:---------------|:----------:| | browsing | Boolean | empty | 控制是否进入查看模式 | 示例 |

  • 功能控制

|配置项|类型|默认值|描述|示例| |:--:|:--:|:-----:|:---------------|:----------:| | controller | 查看 | 桌面|移动 | 将特定项设为 false 来隐藏查看模式下的操作控件 | 示例 | | hotKey | 查看 | 桌面|移动 | 将特定项设为 false 来禁用查看模式下的快捷键 | 示例 | | animate | 查看 | 桌面|移动 | 传入特定的参数指定翻页动画(browsing 动画暂不可配置) 可选值 | 示例 |

  • 界面样式

|配置项|类型|默认值|描述|示例| |:--:|:--:|:-----:|:----------|:----------:| | backdrop | String | "#FFFFFF" | 控制图片放大后的背景色 | 示例 | | zIndex | Number | 1000 | 控制外部容器的 z-index, 防止被其他元素遮挡 | 示例 | | radius | Number | 桌面|移动 | 控制图片在查看模式下的圆角 | 示例 | | edge | Number | 桌面|移动 | 控制图片在查看模式下距离屏幕边缘的距离 | 示例 |

  • 生命周期

|配置项|类型|默认值|描述|示例| |:--:|:--:|:-----:|:----------|:----------:| | onBrowsing | func | (browsing)=>{} | 生命周期方法, 在显示/隐藏时调用, 会回传显示状态 | 示例 | | onZooming | func | (zooming)=>{} | 生命周期方法, 在放大/缩小时调用, 会回传缩放状态 | 示例 | | onSwitching | func | (paging)=>{} | 生命周期方法, 在切换图片时调用, 会回传页码 | 示例 | | onRotating | func | (deg)=>{} | 生命周期方法, 在旋转图片时调用, 会回传角度 | 示例 |

src

"http://zmage.caldis.me/imgSet/childsDream/demo.jpg"

alt

"图片的占位文字,作为图片的标题, 请尽量保持简短"

set

// 如果设置了 Set, 则进入查看模式后第一张图片将会是 set 的首图, 而不是 src
// 如果你需要在查看模式中呈现高精度图片, 可以将其设置为 set 的首图, 或使用 defaultPage 指定
set={[
    {
        // 图片 Url
        src: "http://zmage.caldis.me/imgSet/childsDream/1.jpg",
        // 图片占位文字
        alt: "图片的占位文字,作为图片的标题, 请尽量保持简短",
        // 图片样式
        style: { borderRadius: 30 },
        // 图片类名
        className: 'testClassName'
    },
    {
        // 另一个图片 Url
        src: "http://zmage.caldis.me/imgSet/childsDream/2.jpg",
        // 另一段图片占位文字
        alt: "图片的占位文字,作为图片的标题, 请尽量保持简短",
    }
]}

defaultPage

set: [
    {
        // 图片 Url
        src: "http://zmage.caldis.me/imgSet/childsDream/1.jpg",
        // 图片占位文字
        alt: "图片的占位文字,尽量保持简短,描述图片作用",
    }
]

browsing

browsing={this.state.contrlledZmageState}

controller

controller={{
    // 关闭按钮
    close: true,
    // 缩放按钮
    zoom: true,
    // 下载按钮
    download: true,
    // 旋转按钮
    rotate: true,
    // 翻页按钮
    flip: true,
    // 多页指示
    pagination: true,
}}

hotKey

hotKey={{
    // 关闭(ESC)
    close: true,
    // 缩放(空格)
    zoom: true,
    // 翻页(左右)
    flip: true,
}}

animate

animate={{
    flip: 'fade',
}}

backdrop

backdrop="linear-gradient(90deg, rgba(0,212,255,1) 0%, rgba(26,94,215,1) 100%)"

zIndex

zIndex={19260817}

radius

radius={5}

edge

edge={20}

onBrowsing

onBrowsing={state => {
    console.info("Browsing State: ", state)
}}

onZooming

onZooming={state => {
    console.info("Zooming State: ", state)
}}

onSwitching

onSwitching={page => {
    console.info("Switching page: ", page)
}}

onRotating

onRotating={deg => {
    console.info("Rotating State: ", deg, "deg")
}}

我们随时欢迎发起一个 PR 来帮助我们改进代码 如果发现任何问题, 也欢迎 发起一个ISSUE 来反馈你的意见

react-zmage 基于 MIT licensed 发布