前端开源项目 [Simple Sheet]

2022-07-13 08:59:06 +08:00
 lvming6816077

[ Simple Sheet ] 一款高性能的在线表格 EXCEL 文档系统。

技术栈:

React.js+Mobx+TypeScript

功能和特性:

demo: https://www.nihaoshijie.com.cn/mypro/simple-sheet/index.html

Github: https://github.com/lvming6816077/simple-sheet

相关功能还在持续开发中,感兴趣的同学可以参与一起开发维护!

2730 次点击
所在节点    程序员
19 条回复
musi
2022-07-13 09:04:31 +08:00
demo 里还不支持鼠标滚动
stefanieewu
2022-07-13 09:08:44 +08:00
不支持滚动多选
FakerLeung
2022-07-13 09:11:43 +08:00
属于无法正常使用的程度:
1. B 列完全无法选中单元格,一点击就是直接全选整列。
2. 点 C4 ,D6 高亮并编辑?
3. 拖动 2 列( DE ),却跨了 3 列( DEF )。

cmd+w 了。。。
lvming6816077
2022-07-13 09:16:06 +08:00
@FakerLeung 老哥 你描述的问题 我咋不能复现呢 是用的 Chrome 嘛
lvming6816077
2022-07-13 09:17:12 +08:00
@stefanieewu 还在开发中
@musi
FakerLeung
2022-07-13 09:22:17 +08:00
@lvming6816077 #4
Brave 偶现,要在页面滚动一下,然后滚动表格的滚动条,就容易复现了。
ericgui
2022-07-13 09:39:44 +08:00
你创建一个 github org 吧,比如 github.com/simple-sheet

邀请想参与的人进去一起写代码

不然就算参与进去了,也不好把你死人的 repo 放在自己简历里
ericgui
2022-07-13 09:40:00 +08:00
*私人, 写错字了不好意思
lvming6816077
2022-07-13 10:01:16 +08:00
@ericgui get!
antowa
2022-07-13 13:23:24 +08:00
怎么参与共同开发?想加入
cjh1095358798
2022-07-13 13:42:46 +08:00
这是个什么类型项目,私人开源 demo 吗
passon
2022-07-13 13:45:56 +08:00
代码没有格式化
lvming6816077
2022-07-13 15:03:37 +08:00
@cjh1095358798 目前我自己在开发,创建了一个组织 simple-sheet
laolaowang
2022-07-13 16:08:37 +08:00
加油,口头支持一波
Exuanbo
2022-07-14 01:50:34 +08:00
随便点开几个 component 看了看, 全是 `props: any` …
lvming6816077
2022-07-14 08:36:12 +08:00
@Exuanbo 代码还没有优化完,后续会持续优化
bsg1992
2022-07-17 21:56:33 +08:00
Safari 浏览器 合拼没有内容的单元格后 无法进行输入
Victor69
2022-08-18 02:58:00 +08:00
api 设计有点问题,一边说高性能,一边整个组件直接丢个 data array 就渲染,还不如上个虚拟容器简单。
而且 canvas 对 sheet**本身**的性能影响不大,而是针对不同浏览器之间排版引擎(对齐、字体显示等)的性能问题。看了看 example 你这个只支持 chrome ,那 canvas 其实毫无优势,徒增开发难度,不如套个 tanstack/table + 虚拟滚动

而且个人认为设计一个新的 sheet 组件,从产品上基本的亮点应该是多人协作( yjs )和支持连接 database (例: https://baserow.io/)。如果这些都没有直接还不如打开 office 365 ,或者 Google sheet 。

另外,如果从一款好用的开源 excel component 考虑,从设计角度上应该最外层有一层 data fetcher 做 lazy load (例子: https://refine.dev/)、支持自定义 cell type ( plugin system )这些应该一开始就留有余地,后面改起来的难度和重写一样;计算公式上实现起来又是一个大坑,如果要做动态计算(改一改 cell 相关的 cell 也会更新),要有一个 hypergraph (或者起码是个图),每次加函数做回路检测和 cell 更新,而且计算公式市面上产品都是非常非常基础,从 ws office 就有的那点东西,我觉得可以套一个 serverless 函数,支持 python 科学计算( google sheet 插件里面貌似有类似的功能)

P.S. 这也是我目前在做的东西,以上为个人一点浅见
lvming6816077
2022-08-18 11:43:04 +08:00
@Victor69
高性能这个主要是利用了 React 而不是原生 JS 去实现 cell 的相关操作,这里有待商榷 React 优于原生 JS ,但是目前来说用着并不卡顿;
理论上支持所有现代浏览器,只是目前只在 Chrome 上测试过;

总体来说,因为本身这个项目目前只是作为一个开源项目并且只有我个人在业余时间开发,所以很多功能(实时协作,后端服务,复杂公式等等)都没有完善,也没有精力完善,其实目的是为了给一些对 web sheet 感兴趣的同学入门,当然也也可以参与开发进来。

感谢关注和支持。

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

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

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

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

© 2021 V2EX