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

sw_react_plugs_instruction

v1.0.4

Published

instruction how creat plugs in the react

Downloads

0

Readme

从插件中引用

import { CommomDatePicker } from "hooksplug"; 在需要使用的页面上 import { DatePicker } from 'antd'; const { RangePicker } = DatePicker; 否则无antd样式

注意:

  • onChange事件是回调函数,默认返回选择的起、始的10位时间戳数组,必传
  • num是时间戳位数,类型为number,默认10位,可不传
  • style是自定义设置样式,类型为对象,默认为{},可不传
  • format是时间格式,类型为字符串,默认是'YYYY-MM-DD',可不传
  • disabledInterval是可选择的时间区间,根据选择的第一个时间点,来控制可选择的时间区间(传入的区间),eg:[7, 10],只能选择的第一个时间的前7-30天,后7-30天,默认为[],可不传

制作插件

1⃣️制作

安装node及npm,之后新建一个文件夹,在终端中打开,执行命令npm init,一路回车然后输入yes即可,生成一个package.json, { "name": "swTest", "version": "1.0.0", "description": "", "main": "index.js", "scripts": { "test": "echo "Error: no test specified" && exit 1" }, "author": "", "license": "ISC" },其中name就是插件的名称,默认是文件夹名字;version为版本号,注意每次发布新版本的时候需要手动更新版本号;description是描述;main是入口文件,加载这个插件时读的文件,这个也是最重要的属性,这个属性是别人引用你的插件时,读取的入口文件,在这个文件里,需要你向外暴露接口;author是作者,可以是npm注册的名字。

在根目录下新建src文件夹,里面存放的就是自己的代码片段。

在根目录下新建个 .npmignore(注意要有个.),里面就是npm在发布时会忽略项目中的文件。

在根目录下新建README.md,里面时发布到npm时项目介绍。

2⃣️babel转义

因为很多语法都是ES6及以上,所以需要转义成ES5。

全局安装Babel: npm install -g babel-cli ES6转码规则: npm install babel-preset-es2015 --save-dev react转码规则: npm install babel-preset-react --save-dev ES7不同阶段语法提案的转码规则: npm install babel-preset-stage-0 --save-dev (0 - 3都可以) 根目录下新建.babelrc(同样有.);加入规则 { "presets": [ "es2015", "react", "stage-2" ], "plugins": [] } 一般我们是将代码写在src里面,然后将整个src转义成es5,根目录下运行代码 babel src --out-dir lib ,得到lib文件夹,就是src转义之后的文件了。 修改package.json,里面main修改为lib/index 修改.npmignore文件,增加src/ node_modules/ package-lock.json 3⃣️发布

没有npm账号的先去npm官网注册,官方网站是:https://www.npmjs.com/; 先修改package.json中的name,修改成你的插件名,然后在npm官网查询是否已经被注册了这个名字,有的话修改一下; 项目根目录下执行npm adduser ,输入npm的账号密码还有邮箱,缺一不可; 可以运行npm whoami查看当前用户是否是自己; 运行代码npm publish进行发布; 可以在npm官网右上角点击packages查看自己发布的,有的话发布就成功啦; 在项目之中可以引进自己的插件npm install xxx --save-dev进行使用啦; 4⃣️维护

对插件代码功能进行了拓展或者修改,需要重新发布新版本,除了改代码之外,需要每次手动把package.json中的version进行修改,这是版本号,代表版本改动了。npm使用的版本号规则是semver语义化版本,初始化是1.0.0,依次是主版号.次版号.修订号,主版号是不相容的API修改,次版号是功能性新增,修订号是问题修正。 修改了之后再运行一次npm publish进行发布; 发布之后在运用的项目如何更新呢?(1)如果是npm,由于是自己的插件,可以知道自己的版本修改成了什么,在项目中package.json里面找到依赖包版本,手动改成最新的版本号,然后项目运行npm install --force就可以了;(2)如果是yarn,运行yarn upgrade也ok;(3)由于项目中的依赖包会发生更新,所以有时候我们会安装第三方插件进行查看,npm install -g npm-check-updates,运行ncu 查看可更新包,ncu -u更新package.json,npm install升级到最新版本即可。