English | 简体中文
一套企业级中后台UI的解决方案,致力于解决设计师与前端在工作协同、产品体验一致性、开发效率方面的问题
你可以通过一站式协作平台灵活地定制自己的 DesignSystem,生成设计物料与代码分片到设计师的工具端 FusionCool 及开发者的工具端 Iceworks,同时保证代码和视觉稿之间的一致性
@alifd/next
配合 Fusion Design 解决在页面开发时设计师和前端协同的问题。通过这套体系设计师可以自由的定制组件的 UI 并产出一个 npm 主题包,前端可以直接使用这个主题包不需要关注组件的还原度问题。省去了和设计师反复的去做还原度 Review 的工作量,大幅度的提高了开发效率。
✔ | ✔ | ✔ | 9+ ✔ | ✔ | ✔ | ✔ |
npm install @alifd/next --save
在浏览器中使用 script 和 link 标签直接引入文件,并使用全局变量 Next。我们在 npm 包中提供了 @alifd/next/dist
目录下的 next.js/next.min.js 和 next.css/next.min.css 等文件,也可以通过 unpkg 进行下载。
<link rel="stylesheet" href="https://unpkg.com/@alifd/next/dist/next.css" />
<script src="https://unpkg.com/@alifd/next/dist/next.js"></script>
// 以上引入都是引入的最新版本 @alifd/next
,但我们推荐引入固定版本的next组件,以保证代码稳定
<script src="https://unpkg.com/@alifd/[email protected]/dist/next.min.js"></script>
// 或作为自己的静态资源引入
<script src="../build/public/@alifd/next.js"></script>
@alifd/next
基于react@16
开发,目前并不兼容react@16
以下的版本,且将 react/react-dom 作为 peerDependencies,需要用户手动提前安装或引入。@alifd/next
在处理日期时间相关组件逻辑时,使用了 moment 库,且将 moment 作为 peerDependencies,需要用户手动提前安装或引入。
// 全量引入压缩后的next基础样式
import '@alifd/next/dist/next.min.css';
import { Button, Input } from '@alifd/next';
- 优点:使用简单, 样式无需编译直接使用
- 缺点:当前页面未使用的组件也会被打包
Note: 如果引入 scss 版本的样式,import '@alifd/next/index.scss';
,在 webpack 打包时请使用fast-sass-loader
,否则编译出来的样式文件可能会很大。
原因是@alifd/next
内部,组件之间存在依赖关系,例如 Icon 组件被 Menu 组件依赖。对于 webpack 来讲,在分析依赖阶段,Menu 的 index.scss 和 Icon 的 index.scss 是两个不同的模块,两个文件会独立的在 sass-loader 阶段编译。因此 Icon 的 sass 会被重复编译。使用fast-sass-loader
可以避免样式重复打包的问题。
import Button from '@alifd/next/lib/button';
import '@alifd/next/lib/button/style';
- 优点:按需引入 js 代码、样式代码,不会加载不必要的组件
- 缺点:使用起来过于繁琐,需要手动添加每一个用到的组件 js 代码及样式
2.使用 babel-plugin-import (推荐)
通过 babel-plugin-import 插件,可以将下面的代码
import { Button } from '@alifd/next';
转化为类似下面的代码:
import Button from '@alifd/next/lib/button';
import '@alifd/next/lib/button/style';
babel 配置:
// webpack babel loader option or .babelrc
{
// ...
plugins: [
[
'babel-plugin-import',
{
libraryName: '@alifd/next',
style: true,
},
],
];
}
扫码钉钉群 加入即刻交流与反馈: