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

@eyeear/scene

v1.0.3

Published

场景滚动监控

Readme

Scene

场景滚动监控,元素在窗口可见时、到达指定位置时触发回调,可用于模块、图片懒加载。

安装

npm install @eyeear/scene --save

使用

import Scene from '@eyeear/scene'

OR

<script src="lib/scene.js"></script>
  <div class="wrapper">
      <div class="box">场景1</div>
      <div class="box">...</div>
      ...
  </div>
  new Scene('.wrapper', {
      offsetTop: 40,
      onActive(index, scene) {
          // scene对应场景到指定位置了
      },
      onVisible(scene, index) {
         // scene对应场景在窗口可见了
      }
  })

选项

  new Scene(el, options)

  el 
    - 场景外围容器 设置了选项scene可设为null 一个css选择器或者元素对象
  
  options
    - 选项属性
    - offsetTop 激活的位置相对顶部的偏移  默认 0 
    - scene 手动设置要监控的场景 默认未定义 一个css选择器类名或者元素对象类数组
    - visibled 手动设置可见状态的属性 属性值为true时 onVisible回调在对应scene中只执行一次  默认'visibled' 
    - actived 手动设置激活状态的属性 属性值为true时 onActive回调在对应scene中只执行一次  默认'actived'
    
    - 选项方法
    - onVisible 在视口中可见触发回调 参数(scene, index)
    - onActive 在指定位置时触发回调 参数(index, scene)
  
  instance 实例方法
    - scrollTo(index, duration) 滚动到对应场景
    - destroy() 要销毁实例时调用 注销事件绑定