【Dash】Dash中@callback() 回调函数的Output() 参数

2024-08-21 10:12

本文主要是介绍【Dash】Dash中@callback() 回调函数的Output() 参数,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、Dash 中的 @callback()

在Python中,@callback是一个用于注册回调函数的装饰器

Dash 的回调机制允许开发者创建交互式的Web应用,通过回调函数可以实现前端界面与后端逻辑的交互。

二、@callback() 的概念、定义和应用场景

概念

  • @callback 是 Dash 框架中的一个装饰器,用于将一个普通函数转变成一个回调函数,这个函数可以响应 Dash 应用中的用户交互。

定义

  • @callback 常与 Output 和 Input 类一起使用,定义了当输入组件的值发生变化时,哪个前端组件应该更新,以及如何更新。

应用场景

  • 需要根据用户输入、点击等交互更新前端显示的情况时使用。
  • 例如,当用户调整滑块时更新图表,或者在用户输入文本后显示结果。

三、@callback() 中 的常用类

  • Input():用于指定触发回调的组件和属性。例如:Input('component-id', 'property') 表示当指定组件的属性发生变化时,回调函数将被触发。
  • Output():用于指定回调函数的结果将更新到哪个组件的哪个属性。例如:Output('component-id', 'property') 表示回调函数的返回值将用来更新指定组件的属性。
  • State():用于在回调函数中提供额外的输入值,但它本身的变化不会触发回调。这个可以用于传递组件的当前状态,而不需要更新触发回调函数。

四、@callback() 中的 Output() 有哪些参数?

1、'children'

  • 用于更新组件的子元素。这通常用于容器组件,如 html.Div html.Ul,你可以用它来动态添加或修改内部的 HTML 元素。
import dash
from dash import html
from dash.dependencies import Input, Outputapp = dash.Dash(__name__)app.layout = html.Div([html.Button('Add Test', id='add-text-button', n_clicks=0),html.Div(id='text-container')
])@app.callback(Output('text-container', 'children'),[Input('add-text-button', 'n_clicks')]
)
def add_text(n_clicks):if n_clicks:return [html.P(f'This is text {i}') for i in range(n_clicks)]if __name__ == '__main__':app.run_server(debug=True)

2、'figure'

  • 用于更新图表组件的内容,如 dcc.Graph。这个属性允许你传递图表的数据和配置,Dash 会自动更新图表的显示。
import dash
from dash import dcc, html
from dash.dependencies import Input, Output
import plotly.express as pxapp = dash.Dash(__name__)# 定义应用布局
app.layout = html.Div([# 添加 dcc.Location 组件来捕获 URL 的路径dcc.Location(id='url', refresh=False),# 定义一个 Graph 组件来显示图表dcc.Graph(id='example-graph')
])# 回调函数,根据 URL 路径更新图表
@app.callback(Output('example-graph', 'figure'),[Input('url', 'pathname')]
)
def update_graph(pathname):# 获取鸢尾花数据集df = px.data.iris()# 根据 pathname 来决定图表的数据和类型if pathname:# 假设 pathname 是 'sepal_length', 'sepal_widdth', 'petal_length', 'petal_width' 中的一个# 去除 pathname 前后的斜杠column_name = pathname.strip('/')if column_name in df.columns:fig = px.box(df, y=column_name)return fig# 如果 pathname 不匹配任何列,返回一个空的图表column_list = 'url可拼接:' + ','.join(df.columns)return {'data': [],'layout': {'title': f'No Data<br>{column_list}'}}        # 返回空图表# 运行服务器
if __name__ == '__main__':app.run_server(debug=True)

3、'style'

  • 用于更新组件的 CSS 样式。你可以指定样式字典来改变组件的外观。
import dash
from dash import html
from dash.dependencies import Input, Outputapp = dash.Dash(__name__)app.layout = html.Button('Change Style', id='change-style-button', n_clicks=0)@app.callback(Output('change-style-button', 'style'),[Input('change-style-button', 'n_clicks')]
)
def change_style(n_clicks):if n_clicks % 2 == 1:return {'color': 'white', 'background-color': 'blue'}else:return {'color': 'black', 'background-color': 'lightgray'}if __name__ == '__main__':app.run_server(debug=True)

4、'className'

  • 用于更新组件的 CSS 类名。这可以用于应用预定义的 CSS 样式或 JavaScript 插件。
import dash
from dash import html
from dash.dependencies import Input, Outputapp = dash.Dash(__name__)app.layout = html.Div([html.Button('Change Class', id='change-class-button', n_clicks=0),html.Div('Content', id='content-div'),html.Div(id='class-name-display')
])@app.callback(Output('content-div', 'className'),[Input('change-class-button', 'n_clicks')]
)
def change_class(n_clicks):if n_clicks % 2 == 0:return 'new-class-a'else:return 'new-class-b'@app.callback(Output('class-name-display', 'children'),[Input('content-div', 'className')]
)
def display_class_name(className):return f'The current class name is: {className}'if __name__ == '__main__':app.run_server(debug=True)

 

5、'value'

  • 用于更新输入组件的值,如 dcc.Input dcc.Dropdown
import dash
from dash import dcc, html
from dash.dependencies import Input, Outputapp = dash.Dash(__name__)app.layout = html.Div([dcc.Location(id='url', refresh=False),dcc.Input(id='input-field', value='Initial Value')
])@app.callback(Output('input-field', 'value'),[Input('url', 'pathname')]
)
def update_input_value(pathname):return pathname if pathname else 'No Path Provided'if __name__ == '__main__':app.run_server(debug=True)

 

6、'options'

  • 用于更新下拉列表组件的选项,如 dcc.Dropdown
import dash
from dash import dcc, html
from dash.dependencies import Input, Outputapp = dash.Dash(__name__)app.layout = html.Div([dcc.Location(id='url', refresh=False),dcc.Dropdown(id='my-dropdown')
])@app.callback(Output('my-dropdown', 'options'),[Input('url', 'pathname')]
)
def update_dropdown_options(pathname):if pathname:options = [{'label': f'Option {i}', 'value': f'{i}'} for i in range(1,6)]return optionsif __name__ == '__main__':app.run_server(debug=True)

 

7、'active'

  • 用于更新选项卡或手风琴组件的当前活动项,如 dcc.Tabs dcc.Accordion

8、'selectedData'

  • 用于更新图表组件选中的数据点,如 dcc.Graph

9、'src'

  • 用于更新图片或视频组件的源,如 html.Img html.Video

10、'data'

  • 用于更新图表或数据表组件的数据,如 dcc.Graph dash_table.DataTable

11、'columns'

  • 用于更新数据表组件的列配置,如 dash_table.DataTable

这篇关于【Dash】Dash中@callback() 回调函数的Output() 参数的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1092870

相关文章

详解Spring Boot接收参数的19种方式

《详解SpringBoot接收参数的19种方式》SpringBoot提供了多种注解来接收不同类型的参数,本文给大家介绍SpringBoot接收参数的19种方式,感兴趣的朋友跟随小编一起看看吧... 目录SpringBoot接受参数相关@PathVariable注解@RequestHeader注解@Reque

Java向kettle8.0传递参数的方式总结

《Java向kettle8.0传递参数的方式总结》介绍了如何在Kettle中传递参数到转换和作业中,包括设置全局properties、使用TransMeta和JobMeta的parameterValu... 目录1.传递参数到转换中2.传递参数到作业中总结1.传递参数到转换中1.1. 通过设置Trans的

java如何调用kettle设置变量和参数

《java如何调用kettle设置变量和参数》文章简要介绍了如何在Java中调用Kettle,并重点讨论了变量和参数的区别,以及在Java代码中如何正确设置和使用这些变量,避免覆盖Kettle中已设置... 目录Java调用kettle设置变量和参数java代码中变量会覆盖kettle里面设置的变量总结ja

spring 参数校验Validation示例详解

《spring参数校验Validation示例详解》Spring提供了Validation工具类来实现对客户端传来的请求参数的有效校验,本文给大家介绍spring参数校验Validation示例详... 目录前言一、Validation常见的校验注解二、Validation的简单应用三、分组校验四、自定义校

SpringBoot中Get请求和POST请求接收参数示例详解

《SpringBoot中Get请求和POST请求接收参数示例详解》文章详细介绍了SpringBoot中Get请求和POST请求的参数接收方式,包括方法形参接收参数、实体类接收参数、HttpServle... 目录1、Get请求1.1 方法形参接收参数 这种方式一般适用参数比较少的情况,并且前后端参数名称必须

Python中的异步:async 和 await以及操作中的事件循环、回调和异常

《Python中的异步:async和await以及操作中的事件循环、回调和异常》在现代编程中,异步操作在处理I/O密集型任务时,可以显著提高程序的性能和响应速度,Python提供了asyn... 目录引言什么是异步操作?python 中的异步编程基础async 和 await 关键字asyncio 模块理论

C++11的函数包装器std::function使用示例

《C++11的函数包装器std::function使用示例》C++11引入的std::function是最常用的函数包装器,它可以存储任何可调用对象并提供统一的调用接口,以下是关于函数包装器的详细讲解... 目录一、std::function 的基本用法1. 基本语法二、如何使用 std::function

Andrej Karpathy最新采访:认知核心模型10亿参数就够了,AI会打破教育不公的僵局

夕小瑶科技说 原创  作者 | 海野 AI圈子的红人,AI大神Andrej Karpathy,曾是OpenAI联合创始人之一,特斯拉AI总监。上一次的动态是官宣创办一家名为 Eureka Labs 的人工智能+教育公司 ,宣布将长期致力于AI原生教育。 近日,Andrej Karpathy接受了No Priors(投资博客)的采访,与硅谷知名投资人 Sara Guo 和 Elad G

hdu1171(母函数或多重背包)

题意:把物品分成两份,使得价值最接近 可以用背包,或者是母函数来解,母函数(1 + x^v+x^2v+.....+x^num*v)(1 + x^v+x^2v+.....+x^num*v)(1 + x^v+x^2v+.....+x^num*v) 其中指数为价值,每一项的数目为(该物品数+1)个 代码如下: #include<iostream>#include<algorithm>

C++11第三弹:lambda表达式 | 新的类功能 | 模板的可变参数

🌈个人主页: 南桥几晴秋 🌈C++专栏: 南桥谈C++ 🌈C语言专栏: C语言学习系列 🌈Linux学习专栏: 南桥谈Linux 🌈数据结构学习专栏: 数据结构杂谈 🌈数据库学习专栏: 南桥谈MySQL 🌈Qt学习专栏: 南桥谈Qt 🌈菜鸡代码练习: 练习随想记录 🌈git学习: 南桥谈Git 🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈�