V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
爱意满满的作品展示区。
wyn153409018
V2EX  ›  分享创造

写了好久的一个接近原生体验的 React 图片查看器组件

  •  2
     
  •   wyn153409018 · 2018-02-03 17:10:40 +08:00 · 7191 次点击
    这是一个创建于 2516 天前的主题,其中的信息可能已经有所发展或是发生改变。

    Feature

    • 双击放大指定位置(手势库使用 alloyfinger )
    • 为移动端而生,pc 端也可以正常使用)
    • 性能良好,我用骁龙 810 60fps 没问题。此外理论上支持展示无数张图片,不像大多数轮播图会把所有图片都渲染出来,这个组件同时最多渲染三张(前一张,当前图片,后一张)
    • 兼容性还不错,移动端应该没啥问题,其实我已经拿去在二线互联网公司的一个小产品上线了,不过要求 react16 以上.
    • 有测试(但 coverage 只有可怜的 17%,不知道算 feature 还是 bug ==)

    Todos

    • 多指放大,最早其实实现了,即 github 上的那张 gif,但是不能从指定位置放大所以改成双击了。
    • 组件进入推出动画
    • 重构!因为涉及到同时触摸控制父子元素,edge case 太多了。。。所以代码写的有些乱

    demo

    Edit l2xpwy3xrq

    Github

    一点点不成熟的总结

    第 1 条附言  ·  2018-02-03 18:24:52 +08:00

    demo

    12 条回复    2018-02-06 00:29:11 +08:00
    wyn153409018
        1
    wyn153409018  
    OP
       2018-02-03 17:15:05 +08:00
    补充下,这个组件最麻烦的地方是处理触摸事件,当图片超出屏幕时应该触摸拖拽图片,在屏幕范围内则触摸拖拽整个列表,导致这个组件有些庞大( 24kb ungzipped)
    17 届的应届生,第一次发帖,也希望各位能够多多指点。
    wyn153409018
        2
    wyn153409018  
    OP
       2018-02-03 17:39:17 +08:00
    huiyifyj
        3
    huiyifyj  
       2018-02-03 17:47:25 +08:00
    不错的。mark 一下。
    gaobh
        4
    gaobh  
       2018-02-03 19:08:31 +08:00 via iPhone
    mark
    azh7138m
        5
    azh7138m  
       2018-02-04 12:32:27 +08:00 via Android
    Android7 chrome63,不能放大
    wyn153409018
        6
    wyn153409018  
    OP
       2018-02-04 14:06:38 +08:00
    @azh7138m 我也是安卓 7 chrome 哎,我这里没有问题很奇怪,有啥错误信息么,毕竟上线的东西,有 bug 我就 gg 了
    wyn153409018
        7
    wyn153409018  
    OP
       2018-02-04 14:10:27 +08:00
    @azh7138m 我猜你是不是点的是 loading 动画~
    azh7138m
        8
    azh7138m  
       2018-02-04 14:35:14 +08:00 via Android
    @wyn153409018 你等下,我开个调试看看
    azh7138m
        9
    azh7138m  
       2018-02-04 14:57:30 +08:00 via Android   ❤️ 1
    @azh7138m 不知道啥问题,电脑上没问题,手机上不行,更新到 64 也不行,我觉得是版本的问题,ff57 是可以的
    wyn153409018
        10
    wyn153409018  
    OP
       2018-02-04 15:26:45 +08:00
    @azh7138m 谢谢,我看一下
    sinchang
        11
    sinchang  
       2018-02-05 20:46:46 +08:00
    赞 代码很工整 看的很舒服
    wyn153409018
        12
    wyn153409018  
    OP
       2018-02-06 00:29:11 +08:00
    @sinchang 啊哈,谢谢表扬
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   3549 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 23ms · UTC 04:27 · PVG 12:27 · LAX 20:27 · JFK 23:27
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.