百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

Python使用Dash开发网页应用(二)

myzbx 2025-01-18 22:35 17 浏览

Python Dash开发Web应用的控件基础

本文主要是通过Dash的Checklist组件,简单介绍使用Dash开发的Web应用

展示效果如下:

Dash应用程序由两部分组成:

  • 第一部分是应用程序的布局(Layout),它描述了应用程序的外观。
  • 第二部分描述了应用程序的交互性。

1. Dash的布局Layout

Dash应用的布局描述了应用的外观。布局是一个分层的组件树。

Dash HTML Components(dash.html)为所有HTML tags和HTML属性关键字参数描述提供类,如style, class和id。

Dash核心组件(dash .dcc)生成高级组件,如控件和图形。

Dash Layout有几个特点:

  • 布局由组件树组成
  • 可创建复杂的可复用的组件
  • 核心组件模块dash .dcc包含一个名为Graph的组件,Graph使用开源的plotly.js JavaScript图形库呈现交互式数据可视化。js支持超过35种图表类型,并以矢量质量的SVG和高性能的WebGL呈现图表,详细可参考: plotly.py documentation and gallery
  • 对于编写文本块,可以使用dash.dcc中的Markdown组件
  • Dash核心组件(dash .dcc)包括一组较高级的组件,如下拉菜单、图形、标记块等

1.1 Dash的HTML组件

Dash是一个web应用程序框架,它提供了围绕HTML、CSS和JavaScript的纯Python抽象。而不是编写HTML或使用HTML模板引擎,用Python和Dash HTML Components模块组成布局。

Dash HTML组件模块是Dash的一部分,可以在 https://github.com/plotly/dash 找到它的源代码。

1.2 Dash的Core组件

Dash配备了用于交互用户界面的动态组件。

Dash核心组件模块可以被导入和使用,通过from dash import dcc 并允许访问许多交互式组件,包括下拉菜单、检查列表和滑块。

dcc模块是Dash的一部分,可以在 https://github.com/plotly/dash 找到它的源代码。

2. Dash Core中的Checklist

dcc.Checklist是一个用于呈现一组复选框的组件。

下面我们借助Checklist控件,组建一个简单工程,以说明Dash开发Web应用的一些简单内容

Demo的目录结构如下:

.
└── dash_demo
    ├── app.py
    └── assets
        ├── favicon.ico
        └── img
            ├── julia_50px_icon.png
            ├── python_50px_icon.png
            └── r_50px_icon.png

app.py的内容如下:

from dash import Dash, html, dcc
app = Dash(__name__)
app.title = 'Dash控件教程'
app.layout = html.Div(children=[
    dcc.Checklist(
        options=['Python语言', 'Julia语言', 'R语言'],
        value=['Python语言', 'R语言']
    ),
    dcc.Checklist(
        options=[
            {'label': 'Python语言', 'value': '1'},
            {'label': 'Julia语言', 'value': '2'},
            {'label': 'R语言', 'value': '3'},
        ],
        value=['1', '3']
    ),
    dcc.Checklist(
        options={
            '1': 'Python语言',
            '2': 'Julia语言',
            '3': 'R语言',
        },
        value=['1', '3']
    ),
    dcc.Checklist(
        options=[
            {
                'label': html.Img(src=app.get_asset_url('img/python_50px_icon.png')),
                'value': 'Python语言',
            },
            {
                'label': html.Img(src=app.get_asset_url('img/julia_50px_icon.png')),
                'value': 'Julia语言',
            },
            {
                'label': html.Img(src=app.get_asset_url('img/r_50px_icon.png')),
                'value': 'R语言',
            },
        ],
        value=['Python语言', 'R语言']
    ),
])

if __name__ == '__main__':
    app.run_server(debug=True)

运行工程:python app.py

浏览器访问:http://127.0.0.1:8050

简单说明:

  • assets目录,是官方推荐的用于存放我们的Dash应用所依赖静态资源文件的目录,如依赖的cssjsfavicon.ico、各种图片及字体等静态资源,
  • Dash控件有多种使用形式,很灵活,例如文中的Checklist,选项的标签(用户看到的)和值(传递给回调的)是等价的。使用时,我们更倾向于将它们分开,这样就可以很容易地更改标签,而不更改使用该值的回调逻辑。

相关推荐

STM学习笔记--STM32F10X时钟

一:系统(SYSCLK)时钟3种(注:时钟频率较高)本文引用地址:http://www.eepw.com.cn/article/201609/296750.htmHSI振荡器时钟8MHZHSE振荡...

澜起科技领先启动DDR5时钟驱动芯片试产,助力提升数据速度与稳定性

添加我为微信好友<<<点击左侧,每日精选三只热门板块金股免费领。【澜起科技开启DDR5时钟驱动器芯片试产】澜起科技已启动DDR5第一子代时钟驱动器芯片的生产试验。该产品将用于新...

STM32F030 Nucleo-让MCU全速点灯,其中隐藏的含义(一)

只要是有点基础的骚友,点个灯就是个小KS!但是,我却发现一些猫腻!!!先看程序:从牛卡板卡的硬件原理图得知LD1为ST-Link的RGB指示灯,LD3为牛客板卡的电源指示灯,那么只剩下LD2了,LD2...

西门子-CPU模块的参数设定

右键单击CPU模块所在的行,并选中“对象属性(ObjectProperties…)”选项,可以打开CPU的参数设定页面。通过设定页面不同的标签,可以打开不同的参数设定对象。1.基本参数(Genera...

海湾GST5000主机报时钟电源故障

主板时钟电源主要记录系统的时间,也就是维持系统时钟的准确性。还有记录启动时要用的硬件信息,也就是BⅠOS信息。有好多厂家工控板有独立纽扣电池,如下图一般工控板电池没电,主机开机后系统时间不是准确的时间...

S7-1200 CPU 时钟与 CP 时钟的同步

CPU同步CP时钟按如下步骤组态实现CPU时钟同步CP时钟:1.在CPU属性中激活“通过NTP服务器启动同步时间”,同时激活“CPU与该设备中的模块进行同步”,即实现CPU...

开机需先按F1,开机后时间不准?手把手教你更换纽扣电池解决

台式机开机必按F1?手把手教你更换CR2032纽扣电池,彻底解决BIOS重置问题台式机主板上的CR2032纽扣电池(CMOS电池)是电脑的“记忆电源”,其核心作用是为BIOS芯片持续供电,确保在完全断...

空气钟摆着不动会自己上链,这种神秘装置是如何实现走时的?

我们都知道,积家在钟表领域发明了两个伟大的时计,一个是积家表的翻转表(Reverso),另一个则是积家的空气钟(Atmos),tmos空气钟在其发明近一个世纪后仍然是一项独特而有趣的发明,这种钟是在空...

2013款新帕萨特一键启动不能正常启动一步搞定

2013年购买2013款新帕萨特2.0御尊,一直使用正常,除了正常保养外,2019年更换过火花塞,别的都没更换。2022年2月10日启动时可点火,不能正常启动发动机。还提示驻车制动器故障等,长时间按压...

老板喊你设计一个高效的定时任务系统

【51CTO.com原创稿件】今天想跟大家一起探讨一个听起来很简单的话题:定时任务机制。无非就是一个计时器,到了指定时间就开始跑呗。tooyoung,要是这么简单我还说啥呢,干不就完了。那如果是几千...

三星S6 edge+不一样 双曲面屏新玩儿法

三星GalaxyS6edge+最为耀眼的特点就是它的双曲面侧屏,这是对此前三星S6edge的又一次升级。当然,这一特色为你带来的不仅是看起来爽而已,其实它用起来更爽。今天就为大家详细介绍一下三星...

深度分析:雄鹿队季后赛首轮被淘汰后,字母哥交易时钟正式启动

欢迎关注、点赞、评论、收藏、转发!##【字母哥踩到香蕉皮?再见印第安纳噩梦夜】周二那场加时赛宰雄鹿绝不手软,步行者最后四十秒轰出8-0冲击波。119-118比分活活憋死雄鹿最后一口气——又是五场解决...

用爆火的DeepSeek做了个桌面时钟

最近这DeepSeek是相当火爆啊。大家都在各种宣传它有多厉害,我也很好奇,就学者体验一下。我是个完全不会写代码的小白,没学过没用过,然后看别人都在用AI来替自己完成编程,很简单的样子。先打开浏览器。...

西门子1200PLC基础篇——定时器的具体应用

西门子1200PLC基础篇——定时器的具体应用上一篇我们一起学习了定时器的操作。今天我们用一个案例一起来学习定时器的具体应用。案例要求:Q0.0端停三秒,运行五秒,再停三秒,再运行五秒,依次循环闪烁。...

效率工具:推荐一款极简桌面待办工具

对于职场办公人员来说,每天有各种各样的事项需要处理,如何高效的管理待办事项非常关键。这个时候有一款好用的待办管理软件就可以帮助大家解决这个问题。今天给大家推荐Kite待办这款极简的桌面待办工具,希望...