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

yzhanimageviewer

v1.0.3

Published

给网站和H5应用增加 像微信朋友圈一样的看图功能,可看大图,双击双指缩放,滑动切换图片,点击返回。jQuery plugin for viewing images like Wechat Moments

Downloads

4

Readme

yzhanImageViewer Y 站影像查看器

给网站和H5应用增加 像微信朋友圈一样 的看图功能,可看大图,双击双指缩放,滑动切换图片,点击返回。
A jQuery Plugin for viewing pictures like Wechat moments.

灵感

IMWeb 微信朋友圈项目

演示

  • PC
    • 鼠标及键盘控制:
      https://mantoufan.github.io/yzhanImageViewer/
    • 鼠标模拟触屏:(Shift + 鼠标左键拖动模拟双指缩放)
      https://mantoufan.github.io/yzhanImageViewer/?touch=on
      电脑演示动画
  • 移动版
    请用手机浏览器打开上面的网址或扫码
    • 演示
      演示页二维码
    • 第三方商城
      第三方商城二维码
      移动演示动画

使用

全屏 点击 图片 / 视频
切换 滑动 / 鼠标拖拽 / ←→键 / 小圆点 / 切换按钮
缩放 双指 / 双击
还原 双击 / R键
拖动 单指 / 鼠标拖拽
返回 单击 / ESC键

安装

浏览器

  1. 本插件依赖jQuery,请先引入jQuery
    <script type='text/javascript' src="https://cdn.jsdelivr.net/combine/npm/[email protected]"></script>
  2. 再引入本插件
  • CDN
    <link href="https://cdn.jsdelivr.net/npm/yzhanimageviewer@latest/dist/jquery.yzhanimageviewer.min.css" rel="stylesheet">
    <script src="https://cdn.jsdelivr.net/npm/yzhanimageviewer@latest/dist/jquery.yzhanimageviewer.min.js"></scirpt>
  • 下载到本地 https://github.com/mantoufan/yzhanImageViewer/releases

配置

选项

$(areaSelector).yzhanImageViewer({
    selector: 'img',
    attrSelector: 'src',
    parentSelector: 'div',
    className: 'img-viewer',
    debug: false,
    onChange: function(curIndex, preIndex, viewerElements, socureElements) {},
    onOpen: function(curIndex, viewerElements, socureElements) {},
    onClose: function(curIndex, viewerElements, socureElements) {},
    controls: {
        reverseDrag: {x: true, y: true},
        canChange: false
    }
});
  • areaSelector {jQuery选择器} 区域选择器
    • 后面的所有设置都会应用在这个区域内的图片 / 视频上
    • 同一页面,不同区域,设置相同,可在选择器一次选中这些区域,英文半角逗号,分隔也可
    • 同一页面,不同区域,设置不同,可声明多个jQuery选择器.yzhanImageViewer(options)
  • selector {jQuery选择器} 元素选择器
    • 元素可以是图片(未来包括视频),也可以是包含图片地址属性的元素(懒加载场景)
  • attrSelector {属性名} 属性选择器
    • 元素上的哪个属性,包含真实图片地址。
  • parentSelector {jQuery选择器} [父级元素选择器] 可选
    • 需要对区域内的多张图片分组时,可用该属性标识 每组图片的父级容器。
    • 图片切换只在同组图片间进行。
    • 该属性为空时,整个区域的图片为一组。
  • className {样式名} [查看器样式名] 可选
    • 多个样式名可用 英文半角空格 分隔。
    • 常用属性名:
      • max-width 查看器最大宽度,默认为全屏,设置后,宽度不能超过最大宽度,位置水平居中
      • background-color 查看器背景颜色,默认是黑色,可以设置其他颜色
  • debug {布尔值} [调试模式] 可选
    • 设置为true后,放缩操作时,左上角,会显示被操作影像的坐标。
  • onChange {函数} [切换时调用] 可选
    • 当用户切换 影像 时,调用。
    • 按先后顺序,传入两个参数
      • curIndex 切换后影像在内的索引值,内,按从上到下,从左往右顺序,从0开始,下同
      • preIndex 切换前影像在内的索引值
      • viewerElements :查看器中的元素数组
      • socureElements :文档中的元素数组
  • onOpen {函数} [查看器打开时调用] 可选
    • 当 影像 被点击放大,即 查看器打开时,调用
    • 传入参数
      • curIndex 被放大影像在内的索引值
      • viewerElements :查看器中的元素数组
      • socureElements :文档中的元素数组
  • onClose {函数} [查看器关闭时调用] 可选
    • 点击返回,即 查看器关闭时,调用
    • 传入参数
      • curIndex 关闭前正在浏览的影像在内的索引值
      • viewerElements :查看器中的元素数组
      • socureElements :文档中的元素数组
  • controls {对象} 控件参数 [设置查看器功能] 可选 1.0.1版本新增
    • reverseDrag {对象} 影像移动方向 与 滑动及拖拽方向 方向,默认 与Windows设备体验相同,反向后与 苹果设备 体验相同
      • x {布尔值} false(默认) | true 水平方向是否反向
      • y {布尔值} false(默认) | true 竖直方向是否反向
    • canChange {布尔值} true(默认) | false 是否允许切换

图示

层级关系:areaSelector > parentSelector > selector

方法

  • $.fn.yzhanImageViewer.open({currentUrl, [urls], [onOpen]}) 打开查看器
    • currentUrl {String} 当前地址
    • urls {Array} 所有地址数组,可选
    • onOpen {Function} 当查看器被打开时调用,可选
  • $.fn.yzhanImageViewer.close({[selector], [onClose]}) 关闭查看器
    • selector {String} 元素的选择器,关闭时,查看器逐渐缩小到这个元素,可选,为空时,查看器渐渐隐藏
    • onClose {Function} 当查看器被关闭时调用,可选
  • $.fn.yzhanImageViewer.change({index, [onChange]}) 切换
    • index {Integer} 要跳转第几个影像。内从0开始,小于0,跳转到第一张,大于小组最多的影像数量,跳转到最后一张
    • onChange {Function} 切换时调用,可选

第三方应用

  • rgbaster.js
    https://github.com/briangonzalez/rgbaster.js
    一款优秀的识别图片主题色的JS插件
    引入rgbaster.js 1.0.0

    <script type='text/javascript' src="https://cdn.jsdelivr.net/combine/npm/[email protected]"></script>

    通过rgbaster.js,在点击放大图片onOpen和图片切换onChange时,更新背景色

    /**
    * 使用图片的主要颜色值设置背景色
    * @param {Integer} curIndex 当前图片的索引值
    */
    function setBgWithDominantColor(curIndex) {
        var img = $('.yz-img-list').children().eq(curIndex).children('img')[0];
        if (img.src.indexOf('file://') === -1) {
            RGBaster.colors(img, {
                paletteSize: 1,
                success: function(payload) {
                    $('.yz-img-viewer').css('backgroundColor', payload.palette[0]);
                }
            });
        }
    }
    $('.main').yzhanImageViewer({
        selector: 'img',
        attrSelector: 'src',
        parentSelector: 'div',
        className: 'img-viewer',
        debug: false,
        onChange: function(curIndex, preIndex) {
            setBgWithDominantColor(curIndex);
        },
        onOpen: function(curIndex) {
            setBgWithDominantColor(curIndex);
        }
    });

    完整代码您可以参考我们的演示DEMO源码。

  • shopXO 图片查看器 插件

shopXO 图片查看器 插件介绍

待办事项

  • 支持视频