首页
/ 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讨论区分享使用经验、提出建议或报告问题,共同推动这个强大的协作编辑引擎向前发展。

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

热门内容推荐

最新内容推荐

项目优选

收起
docsdocs
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
149
1.95 K
kernelkernel
deepin linux kernel
C
22
6
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
980
395
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
192
274
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
931
555
openGauss-serveropenGauss-server
openGauss kernel ~ openGauss is an open source relational database management system
C++
145
190
nop-entropynop-entropy
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
8
0
金融AI编程实战金融AI编程实战
为非计算机科班出身 (例如财经类高校金融学院) 同学量身定制,新手友好,让学生以亲身实践开源开发的方式,学会使用计算机自动化自己的科研/创新工作。案例以量化投资为主线,涉及 Bash、Python、SQL、BI、AI 等全技术栈,培养面向未来的数智化人才 (如数据工程师、数据分析师、数据科学家、数据决策者、量化投资人)。
Jupyter Notebook
75
66
openHiTLS-examplesopenHiTLS-examples
本仓将为广大高校开发者提供开源实践和创新开发平台,收集和展示openHiTLS示例代码及创新应用,欢迎大家投稿,让全世界看到您的精巧密码实现设计,也让更多人通过您的优秀成果,理解、喜爱上密码技术。
C
65
518
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
1.11 K
0