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 🙏

© 2026 – Pkg Stats / Ryan Hefner

@kqinfo/ui

v1.17.6-alpha.6

Published

[![NPM version][npm-image]][npm-url] [![Test coverage][codecov-image]][codecov-url] [![npm download][download-image]][download-url]

Downloads

2,255

Readme

凯桥 UI

NPM version Test coverage npm download

使用

$ yarn add @kqinfo/ui

按需加载

安装babel-plugin-import插件

$ yarn add babel-plugin-import -D

修改babel.config.js文件

// babel.config.js
module.exports = {
  plugins: [
+    [
+      'import',
+      {
+        libraryDirectory: 'es',
+        libraryName: '@kqinfo/ui'
+      },
+      '@kqinfo/ui'
+    ]
  ]
};

定制主题

修改remax.config.js文件

module.exports = {
  ...
-  plugins: [less()],
+  plugins: [
+   less({
+     lessOptions: {
+       modifyVars: { '@brand-primary': '#2780d9', '@brand-attract': '#ff9d46' },
+       javascriptEnabled: true
+     }
+   })
+ ]
  ...
};

修改app.tsx文件

+import { ConfigProvider } from '@kqinfo/ui';

const App = (props) => {
-  return props.children;
+  return <ConfigProvider brandAttract={'#ff9d46'} brandPrimary={'#2780d9'}>{props.children}</ConfigProvider>;
};

Icon 更新

更新 ali 图标库后,将其地址复制到根目录下 iconfont 相关的 json 中替换。然后执行 yarn icon

使用源安装

在项目根目录添加.npmrc文件

canvas_binary_host_mirror=https://npm.taobao.org/mirrors/canvas/
sass_binary_site=https://npm.taobao.org/mirrors/node-sass/
phantomjs_cdnurl=https://npm.taobao.org/mirrors/phantomjs/
electron_mirror=https://npm.taobao.org/mirrors/electron/
chromedriver_cdnurl=https://npm.taobao.org/mirrors/chromedriver/
sentrycli_cdnurl=https://cdn.npm.taobao.org/dist/sentry-cli
cypress_download_mirror=https://npm.taobao.org/mirrors/cypress/

yarn安装的话添加.yarnrc文件

canvas_binary_host_mirror: https://npm.taobao.org/mirrors/canvas
registry: https://registry.npm.taobao.org
ENTRYCLI_CDNURL: https://cdn.npm.taobao.org/dist/sentry-cli
sentrycli_cdnurl: https://cdn.npm.taobao.org/dist/sentry-cli

开发

安装依赖

$ yarn

启动服务

$ yarn start

本地调试

建议使用 yalc 进行本地调试

yalc 说明

  • 简介:yalc 是用于本地包调试的轻量“私有仓库”,相比 yarn link/npm link 更稳定,避免符号链接带来的解析问题
  • 安装:使用npx yalc 或全局安装 npm i -g yalcyarn global add yalc
  • 常用命令:
    • 在组件库中:yalc publish 将当前包发布到本地存储
    • 在业务项目中:yalc add @kqinfo/ui 添加依赖到当前项目
    • 组件库修改后:yalc push 将最新变更推送到所有已添加依赖的项目
    • 业务项目移除:yalc remove @kqinfo/ui 从当前项目中移除本地依赖
    • 业务项目更新:yalc update 拉取最近一次发布的版本
  • 注意:
    • yalc 会在使用项目创建 .yalc 目录并维护 yalc.lock 用于版本跟踪
    • 可以在.gitignore中添加.yalc目录,避免提交到版本控制
    • 如需恢复到远程 npm 版本,先在业务项目执行 yalc remove @kqinfo/ui,再通过正常的包管理器安装所需版本
    • 如果遇到不生效的情况,尝试先执行yalc remove @kqinfo/ui,再重新添加依赖,或者rm -rf node_modules/.cache

启动调试

$ yarn dev

本地发布到 yalc

$ yalc publish

在本地项目中添加依赖

$ yalc add @kqinfo/ui

修改后更新到本地项目

$ yalc push

版本发布

  • 组件库版本发布基于release-it,配置在.release-it.json中,通过 git-cliff 自动生成CHANGELOG.md
  • 执行yarn release发布版本,会自动更新CHANGELOG.mdpackage.json版本号并创建版本号 tag
  • 创建 tag 后,会触发 gitlab-ci 自动发布到 npm registry 并更新文档站

编写测试

开发注意项

  • fork到自己名下,再提merge request
  • 样式不要嵌套
  • 样式用less-modules
  • 表单组件暴露valueonChange
  • 不要用图片当icon
  • 尽量暴露节点的class,缩写用cls,比如暴露子项类名就用itemCls
  • 例子尽量写多点