首页
/ Py-Shiny v1.4.0 版本发布:增强应用状态保存与聊天组件功能

Py-Shiny v1.4.0 版本发布:增强应用状态保存与聊天组件功能

2025-07-01 16:48:35作者:戚魁泉Nursing

Py-Shiny 是一个基于 Python 的 Web 应用框架,它允许开发者使用 Python 快速构建交互式 Web 应用程序。该框架特别适合数据科学家和分析师,因为它提供了简单直观的 API 来创建复杂的交互式数据可视化界面。

应用状态保存功能

本次 v1.4.0 版本最显著的改进是引入了应用状态保存(Bookmarking)功能。这一功能允许用户保存当前应用的状态,并在之后恢复该状态。对于需要长时间运行或需要保存中间结果的应用场景特别有用。

在 Shiny Core 模式下,开发者可以通过在创建应用对象时设置 shiny.App(bookmark_store=) 来启用状态保存功能。而在更简洁的 Express 模式下,则需要在应用初始化时使用 shiny.express.app_opts(bookmark_store=) 进行配置。

这一功能的实现涉及多个技术层面的改进,包括状态序列化、URL 编码处理以及状态恢复机制等。开发者现在可以轻松地为用户提供"保存当前状态"和"恢复上次状态"的功能,大大提升了用户体验。

聊天组件功能增强

ui.Chat() 组件在此版本中获得了多项重要更新:

  1. 状态保存支持:新增的 .enable_bookmarking(client) 方法允许聊天组件保存和恢复消息历史及客户端状态。这意味着即使用户刷新页面或稍后返回应用,也能看到之前的对话记录。

  2. 富交互消息:现在聊天消息中可以嵌入各种 Shiny UI 元素,如输入控件(ui.input_select())和输出渲染器(render.DataGrid())。这为构建更复杂的对话式界面提供了可能,例如在聊天过程中收集用户偏好或展示动态数据。

  3. 流式消息处理改进:新增的 .message_stream_context() 方法提供了更灵活的流式消息处理方式,支持嵌套流和内容替换功能。这对于需要动态更新消息内容或构建多级对话流的场景特别有用。

其他重要改进

ui.MarkdownStream() 组件也获得了多项增强:

  • 新增 .latest_stream 属性取代了原有的 .get_latest_stream_result() 方法,提供了更直观的结果访问方式
  • 默认最大宽度设置为 680px 并水平居中,提升了长文本的可读性
  • 修复了宽度和高度设置不生效的问题

导航栏组件(ui.page_navbar()ui.navset_bar())现在能正确应用通过 ui.navbar_options() 设置的主题和其他属性,解决了之前版本中的样式应用不一致问题。

向后兼容性说明

需要注意的是,Express 模式下的 app_opts() 现在要求所有参数都必须使用关键字形式传递。如果现有代码中使用的是位置参数,需要进行相应调整。

此外,<main> 区域在 ui.page_sidebar() 和带侧边栏的 ui.page_navbar() 中的填充行为也得到了修正,现在会严格遵循 fillable 参数的设置。

总结

Py-Shiny v1.4.0 版本通过引入应用状态保存功能和增强聊天组件,进一步扩展了框架的应用场景。这些改进使得开发者能够构建更持久、更交互式的 Web 应用,特别适合需要保存用户进度或实现复杂对话流程的场景。同时,对现有组件的多项修复和优化也提升了框架的稳定性和一致性。

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

项目优选

收起
kernelkernel
deepin linux kernel
C
22
6
docsdocs
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
202
2.17 K
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
208
285
pytorchpytorch
Ascend Extension for PyTorch
Python
61
94
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
977
575
nop-entropynop-entropy
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
9
1
ops-mathops-math
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
550
83
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
1.02 K
399
communitycommunity
本项目是CANN开源社区的核心管理仓库,包含社区的治理章程、治理组织、通用操作指引及流程规范等基础信息
393
27
MateChatMateChat
前端智能化场景解决方案UI库,轻松构建你的AI应用,我们将持续完善更新,欢迎你的使用与建议。 官网地址:https://matechat.gitcode.com
1.2 K
133