Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/cqkqinfo/ui
基于 Remax 全平台 UI 库
https://github.com/cqkqinfo/ui
alipay-mini-program react react-native remax typescript ui-components wechat-mini-program
Last synced: 3 months ago
JSON representation
基于 Remax 全平台 UI 库
- Host: GitHub
- URL: https://github.com/cqkqinfo/ui
- Owner: cqkqinfo
- License: mit
- Created: 2021-09-18T07:00:21.000Z (over 3 years ago)
- Default Branch: master
- Last Pushed: 2022-09-16T05:20:03.000Z (over 2 years ago)
- Last Synced: 2024-05-22T09:05:22.674Z (8 months ago)
- Topics: alipay-mini-program, react, react-native, remax, typescript, ui-components, wechat-mini-program
- Language: TypeScript
- Homepage: https://cqkqinfo.github.io/ui/
- Size: 38.6 MB
- Stars: 76
- Watchers: 3
- Forks: 9
- Open Issues: 16
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# 凯桥 UI
[![NPM version][npm-image]][npm-url] [![Test coverage][codecov-image]][codecov-url] [![npm download][download-image]][download-url]
[npm-image]: https://img.shields.io/npm/v/@kqinfo/ui.svg?style=flat-square
[npm-url]: https://www.npmjs.com/package/@kqinfo/ui
[codecov-image]: https://codecov.io/gh/cqkqinfo/ui/branch/master/graph/badge.svg
[codecov-url]: https://codecov.io/gh/cqkqinfo/ui
[download-image]: https://img.shields.io/npm/dm/@kqinfo/ui.svg?style=flat-square
[download-url]: https://www.npmjs.com/package/@kqinfo/ui## 使用
```bash
$ yarn add @kqinfo/ui
```## 按需加载
安装`babel-plugin-import`插件
```bash
$ yarn add babel-plugin-import -D
```修改`babel.config.js`文件
```diff
// babel.config.js
module.exports = {
plugins: [
+ [
+ 'import',
+ {
+ libraryDirectory: 'es',
+ libraryName: '@kqinfo/ui'
+ },
+ '@kqinfo/ui'
+ ]
]
};```
## 定制主题
修改`remax.config.js`文件
```diff
module.exports = {
...
- plugins: [less()],
+ plugins: [
+ less({
+ lessOptions: {
+ modifyVars: { '@brand-primary': '#2780d9', '@brand-attract': '#ff9d46' },
+ javascriptEnabled: true
+ }
+ })
+ ]
...
};
```修改`app.tsx`文件
```diff
+import { ConfigProvider } from '@kqinfo/ui';const App = (props) => {
- return props.children;
+ return {props.children};
};
```## 使用源安装
在项目根目录添加`.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
```## 开发
安装依赖
```bash
$ yarn
```启动服务
```bash
$ yarn start
```## 本地调试
启动调试
```bash
$ yarn dev
```本地连接
```bash
$ yarn link
```本地项目调试
```bash
$ yarn link @kqinfo/ui
```## 编写测试
- 相关库 [jest](https://jestjs.io/zh-Hans/docs/getting-started) 、[testing-library](https://testing-library.com/docs/react-testing-library/intro)
- [如何编写测试](https://segmentfault.com/a/1190000022054307)## 开发注意项
- 先`fork`到自己名下,再提`merge request`
- 样式不要嵌套
- 样式用`less-modules`
- 表单组件暴露`value`和`onChange`
- 不要用图片当`icon`
- 尽量暴露节点的`class`,缩写用`cls`,比如暴露子项类名就用`itemCls`
- 例子尽量写多点## 钉钉交流群