当前位置: 首页 > news >正文

NiceGUI 是一个基于 Python 的现代 Web 应用框架

NiceGUI 是一个基于 Python 的现代 Web 应用框架,它允许开发者直接使用 Python 构建交互式 Web 界面,而无需编写前端代码。以下是 NiceGUI 的主要功能和特点:

核心功能

1.简单易用的 UI 组件
提供按钮、文本框、下拉菜单、滑块、图表等常见 UI 元素
支持布局管理(水平、垂直、卡片式等)
可自定义样式和交互行为
2. 实时交互
支持双向数据绑定
事件驱动编程模型(点击、输入变化等)
实时更新 UI 内容
3. 数据可视化
集成 Plotly、Matplotlib 等图表库
支持实时数据图表
可展示 3D 图形和复杂数据可视化
4. 多平台支持
可以作为 Web 应用运行
也可以打包为桌面应用(通过 PyInstaller 等工具)
支持移动设备访问
5. 扩展性
可集成自定义 JavaScript 代码
支持与其他 Python 库(如 Pandas、NumPy)无缝协作
可扩展自定义组件

示例代码

下面是一个简单的 NiceGUI 应用示例,展示了基本的 UI 组件和交互功能: UI组件可输出Markdown、HTML、可运行script脚本

from nicegui import ui, Clientname = ui.input(label='你的名字')
button = ui.button('打招呼', on_click=lambda: result.set_text(f'你好,{name.value}!'))
result = ui.label()# 嵌入JavaScript
def run_js():# Execute JavaScript codeui.run_javascript('alert("这是来自JavaScript的弹窗!")')# 嵌入JavaScript
def get_window_width():# Execute JavaScript to get window widthwidth = ui.run_javascript('return window.innerWidth')ui.notify(f'窗口宽度: {width}px')
with ui.row():ui.button('运行JS', on_click=run_js)ui.button('获取窗口宽度', on_click=get_window_width)# 嵌入HTML内容
html_content = """
<div style="background-color:#f0f0f0; padding:10px; border-radius:5px;"><h3>HTML内容展示</h3><p>这是一段嵌入的<strong>HTML</strong>代码</p><button onclick="alert('HTML按钮被点击!')",color="blue">HTML按钮</button>
</div>
"""ui.html(html_content)# 嵌入Markdown内容
markdown_content = """
# Markdown示例这是一个展示**Markdown**功能的示例:1. 列表项1
2. 列表项2
3. 列表项3> 这是一段引用[NiceGUI官网](https://nicegui.io)代码示例:
```python
def hello_world():print("Hello from Markdown!")- **aaa**
- **bbb**
- **ccc**表格1:
|姓名  |  年龄    |城市|
|---|---|---|
|张三|    25     |  北京|
|李四    |30      | 上海|表格2:
| 姓名 | 年龄 | 职业 |
| --- | --- | --- |
| 张三 | 28 | 工程师 |
| 李四 | 32 | 设计师 |
| 王五 | 45 | 产品经理 |"""
ui.markdown(markdown_content)ui.html('<p>-------控件绑定属性-----------</p>') # 绑定属性class Demo:def __init__(self):self.number = 1
demo = Demo()v = ui.checkbox('visible', value=True)
with ui.column().bind_visibility_from(v, 'value'):ui.slider(min=1, max=3).bind_value(demo, 'number')ui.toggle({1: 'A', 2: 'B', 3: 'C'}).bind_value(demo, 'number')ui.number().bind_value(demo, 'number')ui.run()

应用场景

  • 数据仪表板:实时显示和分析数据
  • 交互式工具:构建科学计算、工程或数据分析工具
  • 快速原型开发:无需前端知识即可快速构建 Web 应用原型
  • 桌面应用替代方案:使用 Web 技术构建跨平台桌面应用

NiceGUI 特别适合 Python 开发者快速构建功能丰富的 Web 界面,尤其在数据科学和自动化领域有很大优势。


http://www.lqws.cn/news/73117.html

相关文章:

  • Windows10-ltsc-2019 使用 PowerShell 安装安装TranslucentTB教程(不通过微软商店安装)
  • Qt概述:基础组件的使用
  • 动态类型语言和静态类型语言
  • 【MySQL基础】库的操作:创建、删除与管理数据库
  • [ Qt ] | 与系统相关的操作(一):鼠标相关事件
  • 分布式锁优化:使用Lua脚本保证释放锁的原子性问题
  • 网络安全的学习路线是怎么样的?
  • 【C语言】C语言经典小游戏:贪吃蛇(下)
  • 用 Whisper 打破沉默:AI 语音技术如何重塑无障碍沟通方式?
  • 【iOS】YYModel源码解析
  • Git GitHub Gitee
  • ISBN书号查询接口如何用PHP实现调用?
  • 房屋租赁系统 Java+Vue.js+SpringBoot,包括房屋类型、房屋信息、预约看房、合同信息、房屋报修、房屋评价、房主管理模块
  • Python训练营打卡 Day26
  • JavaScript性能优化:实战技巧提升10倍速度
  • 2025年—Comfy UI 和 Stable Diffusion底层原理
  • docker可视化工具
  • 【头歌实验】Keras机器翻译实战
  • volatile,synchronized,原子操作实现原理,缓存一致性协议
  • 【JAVA后端入门基础001】Tomcat 是什么?通俗易懂讲清楚!
  • 类和对象:实现日期类
  • Windows采用npx方式本地部署n8n
  • Linux(信号)
  • 并发编程的源头
  • 探索 Dify 的工作流:构建智能应用的新范式
  • Flink CDC将MySQL数据同步到数据湖
  • Kafka集成Flume/Spark/Flink(大数据)/SpringBoot
  • 【设计模式-3.6】结构型——桥接模式
  • React 组件异常捕获机制详解
  • 打卡第34天:MLP神经网络训练