首页
/ Univer v0.5.4 版本发布:表格协作编辑引擎的重大更新

Univer v0.5.4 版本发布:表格协作编辑引擎的重大更新

2025-06-07 02:59:11作者:柯茵沙

Univer 是一款开源的文档、表格和演示文稿协作编辑引擎,它提供了强大的功能和灵活的 API,使开发者能够轻松构建在线协作办公应用。最新发布的 v0.5.4 版本带来了多项重要改进和新特性,特别是在表格编辑功能方面有了显著增强。

核心功能升级

1. 增强的颜色选择器

新版本引入了支持自定义颜色的高级颜色选择器组件。这个改进不仅提供了更丰富的颜色选择体验,还允许用户输入十六进制颜色代码或使用取色器精确选择颜色。对于需要精确色彩管理的企业应用场景,这一功能尤为重要。

2. 智能粘贴功能

v0.5.4 版本新增了选择性粘贴上下文菜单,当用户执行粘贴操作时,系统会自动弹出菜单让用户选择粘贴选项。这一设计显著提升了数据处理的灵活性,用户可以选择仅粘贴值、格式或公式等特定内容,避免了不必要的格式冲突。

API 体系增强

1. 事件监听机制

新版本扩展了事件系统,为工作簿和工作表添加了多种事件监听能力:

// 监听单元格点击事件
univerAPI.getActiveWorkbook().addEvent('CellClicked', (params) => {
    console.log('单元格被点击:', params);
});

// 监听单元格悬停事件
univerAPI.getActiveWorkbook().addEvent('CellHover', (params) => {
    console.log('鼠标悬停在单元格上:', params);
});

这些事件为开发者提供了更细粒度的交互控制能力,使得构建响应式应用变得更加容易。

2. 公式系统改进

公式注册现在支持 lambda 函数,这为动态公式创建提供了更大的灵活性:

// 使用lambda函数注册自定义公式
formulaEngine.registerFunction('CUSTOM_SUM', (args) => {
    return args.reduce((a, b) => a + b, 0);
});

3. 文本搜索API

新增的文本搜索API使得在文档中查找特定内容变得非常简单:

// 创建文本查找器
const textFinder = await univerAPI.createTextFinderAsync('搜索内容');
// 查找所有匹配项
const ranges = textFinder.findAll();
ranges.forEach((range) => {
    console.log('找到匹配项位置:', range.getA1Notation());
});

架构优化与兼容性

1. 异步API升级

为了提高性能和响应能力,图像操作相关的API已升级为异步版本:

// 异步设置图像位置
await image.setPositionAsync(row, column);
// 异步调整图像大小
await image.setSizeAsync(width, height);

2. UI扩展机制

新增的registerUIPartAPI允许开发者自定义UI组件:

// 注册自定义头部组件
univerAPI.registerUIPart(BuiltInUIPart.CUSTOM_HEADER, 
    () => React.createElement('h1', null, '我的自定义标题'));

问题修复与性能优化

  1. 改进了工具提示的显示逻辑,使其在不同分辨率下都能正确显示
  2. 修复了包含引号的工作表名称处理问题
  3. 优化了字体拦截器,提高了文本渲染性能
  4. 改进了边框粘贴逻辑,确保新边框能正确覆盖原有边框

未来展望

v0.5.4版本为即将到来的0.6.0版本奠定了基础。开发团队正在积极工作,计划在下一个主要版本中引入对React 19的支持,这将带来更好的性能和开发体验。同时,团队也在持续优化核心架构,为开发者提供更稳定、更强大的API体系。

对于正在使用Univer构建应用的开发者,建议开始逐步迁移到新的API命名规范,如将createUniverSheet替换为createWorkbook,以确保未来版本的兼容性。

Univer作为一个快速发展的开源项目,其社区也在不断壮大。开发者可以通过GitHub讨论区分享使用经验、提出建议或报告问题,共同推动这个强大的协作编辑引擎向前发展。

登录后查看全文
热门项目推荐

项目优选

收起
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
178
262
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
868
513
openGauss-serveropenGauss-server
openGauss kernel ~ openGauss is an open source relational database management system
C++
129
183
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
268
308
HarmonyOS-ExamplesHarmonyOS-Examples
本仓将收集和展示仓颉鸿蒙应用示例代码,欢迎大家投稿,在仓颉鸿蒙社区展现你的妙趣设计!
Cangjie
398
373
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
1.07 K
0
ShopXO开源商城ShopXO开源商城
🔥🔥🔥ShopXO企业级免费开源商城系统,可视化DIY拖拽装修、包含PC、H5、多端小程序(微信+支付宝+百度+头条&抖音+QQ+快手)、APP、多仓库、多商户、多门店、IM客服、进销存,遵循MIT开源协议发布、基于ThinkPHP8框架研发
JavaScript
93
15
note-gennote-gen
一款跨平台的 Markdown AI 笔记软件,致力于使用 AI 建立记录和写作的桥梁。
TSX
83
4
cherry-studiocherry-studio
🍒 Cherry Studio 是一款支持多个 LLM 提供商的桌面客户端
TypeScript
599
58
GitNextGitNext
基于可以运行在OpenHarmony的git,提供git客户端操作能力
ArkTS
10
3