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 🙏

© 2025 – Pkg Stats / Ryan Hefner

vue3-image-preview

v0.2.7

Published

Vue3图片预览的组件、函数及命令

Downloads

200

Readme

Vue3-Image-Preview

Vue3的图片预览插件,内置图片预览组件、图片预览指令以及图片预览函数。使用起来灵活方便,可以满足大部分针对图片预览的需求。

安装 Install

npm install vue3-image-preview

or

yarn add vue3-image-preview

局部引入 Part Import

在要使用的.vue文件中,引入vue3-image-preview

import {preview, vPreview, Vue3ImagePreview} from 'vue3-image-preview';

其中preview为图片预览函数,vPreview为图片预览指令(v-preview:需要在directives属性中注册),Vue3ImagePreview为图片预览组件(需要在components属性中注册)。

全局引入 Global Import

在入口文件中引入vue3-image-preview,并且使用.use()安装全局插件。 v-preview已注册为全局指令,Vue3ImagePreview已注册为全局组件。

import { createApp } from 'vue';
import App from './App.vue';
import preview from 'vue3-image-preview';

createApp(App).use(preview).mount('#app');

preview函数需要通过getCurrentInstance(Vue3的Composition Api)来引入。

const {proxy} = getCurrentInstance() as any;

proxy.preview({
    images: state.images1,
    index: state.index
});

preview函数

示例

<button @click="preview1Event">预览1</button>
<button @click="preview2Event">预览2</button>
<button @click="preview3Event">预览3</button>
...
setup() {
    // 响应式数据
    const state: any = reactive<any>({
        image: 'https://www.43cx.com/d/file/20220704/e1eb727dc76e4dfc916048b32ab9d50c.jpg',
        images1: [
          'https://img.phb123.com/uploads/allimg/200615/60-2006151H317-52.jpg',
          'https://img.phb123.com/uploads/allimg/200615/60-2006151H318.jpg'
        ],
        images2: [
          {url: 'https://www.43cx.com/d/file/20220704/87fb4397c47fab8b9fb9496e5279591d.jpg'},
          {url: 'https://www.43cx.com/d/file/20220704/a958a8b2ae53bdf22d318ce0356d3ab8.jpg'}
        ],
        index: 0
    });
    
    const preview1Event = () => {
        preview({
          images: state.image
        });
    };
    
    const preview2Event = () => {
        preview({
          images: state.images1,
          index: state.index
        });
    };
    
    const preview3Event = () => {
        preview({
            images: state.images2,
            index: state.index
        });
    };
    
    return {
        ...toRefs(state),
        preview1Event,
        preview2Event,
        preview3Event
    };
}

function.gif

参数

| 属性 | 描述 | 类型 | 默认值 | 必填 | | ---------- | ------------------------------------------------------------ | ------ | ------ | ------ | | images | 当前预览的图片资源或图片资源数组。 | String/Array | "" | 是 | | index | 初始化预览图片的索引,仅当images类型为Array时可用。 | Number | 0 | 否 | | key | 仅当images为对象数组时,key为数组里对象的图片资源的属性名。 | String | "url" | 否 | | zoom | 缩放事件的缩放速度。 | Number | 1.2 | 否 |

v-preview指令

示例

默认,直接使用v-preview指令,会打开单个预览组件。

<img v-preview src="https://img.phb123.com/uploads/allimg/200615/60-2006151H317-52.jpg"/>

directive-default.gif

分组,使用v-preview:name指令,指令值相同的都会在同一个预览组件中打开。

<img v-preview:name="name1" src="https://img.phb123.com/uploads/allimg/200615/60-2006151H318-52.jpg"/>
<img v-preview:name="name1" src="https://img.phb123.com/uploads/allimg/200615/60-2006151H318-51.jpg"/>

<img v-preview:name="name2" src="https://img.phb123.com/uploads/allimg/200615/60-2006151H317-50.jpg"/>
<img v-preview:name="name2" src="https://img.phb123.com/uploads/allimg/200615/60-2006151H317-51.jpg"/>

directive-group.gif

缩放,使用v-preview:zoom指令,会改变缩放事件的缩放速度。

<img v-preview:zoom="zoom1" src="https://www.pipicats.com/uploadfile/2022/1214/202212141670990665241976.jpg"/>

directive-scale.gif

配置,v-preview的值为属性包含"name","zoom"的对象。

<img v-preview="config1" src="https://www.pipicats.com/uploadfile/2022/1214/202212141670990664685286.jpg"/>
<img v-preview="config2" src="https://www.pipicats.com/uploadfile/2022/1214/202212141670990665512352.jpg"/>
<img v-preview="config3" src="https://www.pipicats.com/uploadfile/2022/1214/202212141670990665810075.jpg"/>
<img v-preview="config4" src="https://www.pipicats.com/uploadfile/2022/1214/202212141670990665451069.jpg"/>

directive-config.gif

响应式数据

setup() {
  const {proxy} = getCurrentInstance() as any;
  // 响应式数据
  const state: any = reactive<any>({
    name1: 'name1',
    name2: 'name2',
    zoom1: 1.4,
    zoom2: 1.1,
    config1: {name: 'name3'},
    config2: {zoom: 1.1},
    config3: {name: 'name4', zoom: 1.4},
    config4: {name: 'name4', zoom: 1.1}
  });

  return {
    ...toRefs(state)
  };
}

| 参数 | 描述 | 类型 | 默认值 | 必填 | | ---------- | ------------------------------------------------------------ | ------ | ------ | ------ | | name | 图片分组的名称。 | String | - | 否 | | zoom | 缩放事件的缩放速度。 | Number | 1.2 | 否 |

Vue3ImagePreview组件

所有包裹在Vue3ImagePreview组件里的img,都会在同一个预览组件中打开。

<Vue3ImagePreview>
    <img src="https://img.phb123.com/uploads/allimg/200615/60-2006151H318-54.jpg">
    <img src="https://img.phb123.com/uploads/allimg/200615/60-2006151H318-50.jpg"/>
</Vue3ImagePreview>

<Vue3ImagePreview :zoom="1.1">
    <img src="https://www.pipicats.com/uploadfile/2022/1214/202212141670990665503106.jpg">
    <img src="https://www.pipicats.com/uploadfile/2022/1214/202212141670990666859115.jpg"/>
</Vue3ImagePreview>

component.gif

| 属性 | 描述 | 类型 | 默认值 | 必填 | | ---------- | ------------------------------------------------------------ | ------ | ------ | ------ | | zoom | 缩放事件的缩放速度。 | Number | 1.2 | 否 |

  • 演示地址