自己写的 一套实现 UWP Design 和 Fluent Design 的 React 开源 UI 库(多图)

2017-06-19 16:06:08 +08:00
 myxvisual

官方在线文档GitHub 地址

关于 React-UWP

React-UWP 主要是在去年下半年开始开发的,因为对 Windows 的 UWP 设计规范情有独钟,而自己又是 React 热衷者,而 WinJS 组件又比较简陋粗糙的,于是 React-UWP 就变成个人业余的长期项目了。

一开始,技术选型就是 TypeScript 和 React, 因为 TypeScript 在这大型的代码管理上比普通 Babel 项目好,主要体现在 API 修改和类型检查方面,每次修改 API 在编译时就能把已知错误检测出来。编写样式主要通过 Inline-style 写的(一部分考虑到以后支持 React-Native ),Polyfill 主要通过 inline-style-prefixer 实现的。因为 React-UWP 的主题是完全自己搭配的,所以也用到了 React Context 的属性,所有组件都是通过 context 的 theme 来配置的。其中从 Material-UI 学到不少东西,项目管理,脚本构建等等。

今年五月辞职后,就开始全职开发 React-UWP 了,这时候官方出了新的 Fluent Design System,于是乎,也为 React-UWP 所有组件添加 Fluent Design 的效果。总而言之,这是个还算花了多精力开发的 UI 库,接触学习的前端内容也挺多的。开发 Docs 文档的时候,比较有意思,都会一开始在 Illustrator 上画原型,然后再写出来。

使用场景

React-UWP 主要适合于比较现代化的网页设计,例如 WebApp、官网首页、新闻资讯网站等等,当然这只是一个 UWP 设计规范的 UI 库 而已,你可以从全局 Context 样式中自己设计更好的 Web 应用。 浏览器兼容

React-UWP 支持 所有的现代浏览器,支持 IE9 With Polyfills 或以上。(就是 React 的浏览器兼容)。

开发技术与特点

NPM + Webpack + TypeScript + React 基于 Web 开发的 API 设计,部分和 Xaml 的 API 有所不同 49+ 组件 封装了针对浏览器的 ScrollReveal 组件 封装了基于 react-transition-group 的 Animate 组件

完整的组件文档

React-UWP 的文档,详细的包含了每个组件的使用和介绍该组件的 Props 和 Members。

自定义的色板

部分组件截图展示(四个主题)

更多的样式,自定义颜色,自定义背景,可以访问 官方文档 尝试。

后记

React-UWP 是完全可以自定义整个主题的,就算有些组件不符合特定的产品需求,也是可以对其组件进行自定义样式的。

4594 次点击
所在节点    前端开发
28 条回复
droiz
2017-06-19 16:50:30 +08:00
图挂了?
learnshare
2017-06-19 17:13:52 +08:00
checkbox.unsure 没有对齐。

我记得微软有一套 Web UI,不过没有跟进新的设计
myxvisual
2017-06-19 17:57:58 +08:00
@droiz https://zhuanlan.zhihu.com/p/27366884 这个是知乎文章,图挂了看这个吧
myxvisual
2017-06-19 17:59:06 +08:00
@learnshare 是挺旧的,而且组件不多,这个写了一年多吧,只差几个组件,而且支持 Fluent Design,所以只是实现阶段
nannanziyu
2017-06-19 18:02:43 +08:00
真漂亮,支持
droiz
2017-06-19 18:28:56 +08:00
@myxvisual 挺不错的,支持。
myxvisual
2017-06-19 18:52:55 +08:00
@nannanziyu @droiz 谢谢~~
myxvisual
2017-06-19 22:48:03 +08:00
@learnshare 确实是没对齐,现在修复了,下个版本发,谢谢了
myxvisual
2017-06-19 22:48:39 +08:00
@learnshare 我以为我显示器问题...
Tunar
2017-06-19 22:53:41 +08:00
确实好看,不过我不用 React,可惜了,真心好看
yu7er
2017-06-19 23:04:30 +08:00
手机打开好卡。。
cinextio
2017-06-19 23:05:01 +08:00
微软有个 Fabric Office 的 React 组件库
cbais7890
2017-06-19 23:09:41 +08:00
完成度很高, 细节也很棒!
不过首页的 DEMO 堆砌导致有点卡顿
myxvisual
2017-06-19 23:15:20 +08:00
@yu7er 确实有点卡,可能是太多组件了,需要优化下~
myxvisual
2017-06-19 23:42:57 +08:00
@cinextio 嗯,年末差不多完成时吓死,以为重复了,幸好无论是技术栈和 UI 都差别很大~
myxvisual
2017-06-19 23:43:27 +08:00
@cbais7890 嗯嗯,谢谢,应该会重新设计下首页的展示吧
leedstyh
2017-06-20 00:04:46 +08:00
用的 inline style,有个 meterial design 的库 material-ui 之前用的也是 inline style,但是说是会有性能问题,下一个版本改用 css in js 了,不知道楼主考虑这个问题没

确实是太漂亮了。用 win10 的时候,就特别喜欢这个他的界面,没想到 port 到 react 了,太好了!
myxvisual
2017-06-20 00:24:51 +08:00
@leedstyh 谢谢建议,在考虑,持续观察下 material-ui 下,因为我想下一步是支持 React-Native,会看看情况的~
hronro
2017-06-20 01:05:23 +08:00
那个毛玻璃的效果是怎么做的呢?是 CSS filter 吗,我记得这个只能把某个元素整个的模糊掉
codehz
2017-06-20 08:07:00 +08:00
我记得 fluent design 关于视觉效果很重要的一点就是各种光照效果。。。因为那是材质和全局光照进行渲染的(就像游戏引擎那样)。。。然而这一点是很难在网页端复现的,除非用完全使用 WebGL 进行渲染。。。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/369571

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX