Part 2. Basic Callbacks | Dash for Python Documentation (2024)

This is the 2nd chapter of the Dash Fundamentals.
The previous chapter covered the Dash app layout
and the next chapter covers interactive graphing.
Just getting started? Make sure to install the necessary dependencies.

In the previous chapter we learned that app.layout describes what the app looks like and is a hierarchical tree of components.
The Dash HTML Components (dash.html) module provides classes for all of the HTML tags, and the keyword arguments describe the HTML attributes like style, className, and id.
The Dash Core Components (dash.dcc) module generates higher-level components like controls and graphs.

This chapter describes how to make your Dash apps using callback functions: functions that are automatically called by Dash whenever an input component’s property changes, in order to update some property in another component (the output).

For optimum user-interaction and chart loading performance, production
Dash apps should consider the Job Queue,
HPC, Datashader,
and horizontal scaling capabilities of Dash Enterprise.

Let’s get started with a simple example of an interactive Dash app.

Simple Interactive Dash App

If you’re using Dash Enterprise’s Data Science Workspaces,
copy & paste the below code into your Workspace (see video).

Find out if your company is using Dash Enterprise

from dash import Dash, dcc, html, Input, Output, callbackapp = Dash(__name__)app.layout = html.Div([ html.H6("Change the value in the text box to see callbacks in action!"), html.Div([ "Input: ", dcc.Input(id='my-input', value='initial value', type='text') ]), html.Br(), html.Div(id='my-output'),])@callback( Output(component_id='my-output', component_property='children'), Input(component_id='my-input', component_property='value'))def update_output_div(input_value): return f'Output: {input_value}'if __name__ == '__main__': app.run(debug=True)
Change the value in the text box to see callbacks in action!

Input:


Let’s break down this example:

  1. The “inputs” and “outputs” of our application are described
    as the arguments of the @callback decorator.

Learn more about using the @callback decorator.

a. By writing this decorator, we’re telling Dash to call this function for us whenever the value of the “input” component (the text box) changes in order to update the children of the “output” component on the page (the HTML div).

b. You can use any name for the function that is wrapped by the @callback decorator. The convention is that the name describes the callback output(s).

c. You can use any name for the function arguments, but you must use the same names inside the callback function as you do in its definition, just like in a regular Python function. The arguments are positional by default: first the Input items and then any State items are given in the same order as in the decorator. You also have the option to use named keyword arguments, instead of positional. See the Flexible Callback Signatures chapter for more information.

d. You must use the same id you gave a Dash component in the app.layout when referring to it as either an input or output of the @callback decorator.

e. The @callback decorator needs to be directly above the callback function declaration. If there is a blank line between the decorator and the function definition, the callback registration will not be successful.

f. If you’re curious about what the decorator syntax means under the hood, you can read this StackOverflow answer and learn more about decorators by reading PEP 318 – Decorators for Functions and Methods.

  1. In Dash, the inputs and outputs of our application are simply the
    properties of a particular component. In this example,
    our input is the “value” property of the component that has the ID
    my-input”. Our output is the “children” property of the
    component with the ID “my-output”.
  2. Whenever an input property changes, the function that the
    callback decorator wraps will get called automatically.
    Dash provides this callback function with the new value of the input property as
    its argument, and Dash updates the property of the output component
    with whatever was returned by the function.
  3. The component_id and component_property keywords are optional
    (there are only two arguments for each of those objects).
    They are included in this example for clarity but will be omitted in the rest of the documentation for the sake of brevity and readability.
  4. Don’t confuse the dash.dependencies.Input object and the dcc.Input object. The former is just used in these callback definitions and the latter is an actual component.
  5. Notice how we don’t set a value for the children property of the
    my-output component in the layout. When the Dash app starts, it
    automatically calls all of the callbacks with the initial values of the
    input components in order to populate the initial state of the output
    components. In this example, if you specified the div component as
    html.Div(id='my-output', children='Hello world'),
    it would get overwritten when the app starts.

It’s sort of like programming with Microsoft Excel:
whenever a cell changes (the input), all the cells that depend on that cell (the outputs)
will get updated automatically. This is called “Reactive Programming” because the outputs react to changes in the inputs automatically.

Remember how every component is described entirely through its
set of keyword arguments? Those arguments that we set in
Python become properties of the component,
and these properties are important now.
With Dash’s interactivity, we can dynamically update any of those properties
using callbacks. Often we’ll update the children property of HTML
components to display new text (remember that children is responsible for the contents of a component) or the figure property of a dcc.Graph
component to display new data. We could also update the style of a
component or even the available options of a dcc.Dropdown component!

Let’s take a look at another example where a dcc.Slider updates
a dcc.Graph.

Dash App Layout With Figure and Slider

from dash import Dash, dcc, html, Input, Output, callbackimport plotly.express as pximport pandas as pddf = pd.read_csv('https://raw.githubusercontent.com/plotly/datasets/master/gapminderDataFiveYear.csv')app = Dash(__name__)app.layout = html.Div([ dcc.Graph(id='graph-with-slider'), dcc.Slider( df['year'].min(), df['year'].max(), step=None, value=df['year'].min(), marks={str(year): str(year) for year in df['year'].unique()}, id='year-slider' )])@callback( Output('graph-with-slider', 'figure'), Input('year-slider', 'value'))def update_figure(selected_year): filtered_df = df[df.year == selected_year] fig = px.scatter(filtered_df, x="gdpPercap", y="lifeExp", size="pop", color="continent", hover_name="country", log_x=True, size_max=55) fig.update_layout(transition_duration=500) return figif __name__ == '__main__': app.run(debug=True)

Theming with Dash Enterprise Design Kit

Default Theme
Part 2. Basic Callbacks | Dash for Python Documentation (1)

Mars Theme
Part 2. Basic Callbacks | Dash for Python Documentation (2)

Neptune Theme
Part 2. Basic Callbacks | Dash for Python Documentation (3)

Miller Theme
Part 2. Basic Callbacks | Dash for Python Documentation (4)

Extrasolar Theme
Part 2. Basic Callbacks | Dash for Python Documentation (5)

Preset Themes
Part 2. Basic Callbacks | Dash for Python Documentation (6)

In this example, the "value" property of the dcc.Slider is the
input of the app, and the output of the app is the "figure" property of the
dcc.Graph.
Whenever the value of the dcc.Slider changes, Dash calls the
callback function update_figure with the new value. The function filters the
dataframe with this new value, constructs a figure object,
and returns it to the Dash application.

There are a few nice patterns in this example:

  1. We use the Pandas library to
    load our dataframe at the start of the app:
    df = pd.read_csv('...').
    This dataframe df is in the global state of the app and can be
    read inside the callback functions.
  2. Loading data into memory can be expensive. By loading querying data at
    the start of the app instead of inside the callback functions, we ensure
    that this operation is only done once – when the app server starts. When a user
    visits the app or interacts with the app, that data (df) is already in memory.
    If possible, expensive initialization (like downloading or querying
    data) should be done in the global scope of the app instead of within
    the callback functions.
  3. The callback does not modify the original data, it only creates copies
    of the dataframe by filtering using pandas.
    This is important: your callbacks should never modify variables
    outside of their scope
    . If your callbacks modify global state, then one
    user’s session might affect the next user’s session and when the app is
    deployed on multiple processes or threads, those modifications will not
    be shared across sessions.
  4. We are turning on transitions with layout.transition to give an idea
    of how the dataset evolves with time: transitions allow the chart to
    update from one state to the next smoothly, as if it were animated.

Dash App With Multiple Inputs

In Dash, any “output” can have multiple “input” components.
Here’s a simple example that binds five inputs
(the value property of two dcc.Dropdown components,
two dcc.RadioItems components, and one dcc.Slider component)
to one output component (the figure property of the dcc.Graph component).
Notice how app.callback lists all five Input items after the Output.

from dash import Dash, dcc, html, Input, Output, callbackimport plotly.express as pximport pandas as pdapp = Dash(__name__)df = pd.read_csv('https://plotly.github.io/datasets/country_indicators.csv')app.layout = html.Div([ html.Div([ html.Div([ dcc.Dropdown( df['Indicator Name'].unique(), 'Fertility rate, total (births per woman)', id='xaxis-column' ), dcc.RadioItems( ['Linear', 'Log'], 'Linear', id='xaxis-type', inline=True ) ], style={'width': '48%', 'display': 'inline-block'}), html.Div([ dcc.Dropdown( df['Indicator Name'].unique(), 'Life expectancy at birth, total (years)', id='yaxis-column' ), dcc.RadioItems( ['Linear', 'Log'], 'Linear', id='yaxis-type', inline=True ) ], style={'width': '48%', 'float': 'right', 'display': 'inline-block'}) ]), dcc.Graph(id='indicator-graphic'), dcc.Slider( df['Year'].min(), df['Year'].max(), step=None, id='year--slider', value=df['Year'].max(), marks={str(year): str(year) for year in df['Year'].unique()}, )])@callback( Output('indicator-graphic', 'figure'), Input('xaxis-column', 'value'), Input('yaxis-column', 'value'), Input('xaxis-type', 'value'), Input('yaxis-type', 'value'), Input('year--slider', 'value'))def update_graph(xaxis_column_name, yaxis_column_name, xaxis_type, yaxis_type, year_value): dff = df[df['Year'] == year_value] fig = px.scatter(x=dff[dff['Indicator Name'] == xaxis_column_name]['Value'], y=dff[dff['Indicator Name'] == yaxis_column_name]['Value'], hover_name=dff[dff['Indicator Name'] == yaxis_column_name]['Country Name']) fig.update_layout(margin={'l': 40, 'b': 40, 't': 10, 'r': 0}, hovermode='closest') fig.update_xaxes(title=xaxis_column_name, type='linear' if xaxis_type == 'Linear' else 'log') fig.update_yaxes(title=yaxis_column_name, type='linear' if yaxis_type == 'Linear' else 'log') return figif __name__ == '__main__': app.run(debug=True)

Theming with Dash Enterprise Design Kit

Default Theme
Part 2. Basic Callbacks | Dash for Python Documentation (7)

Mars Theme
Part 2. Basic Callbacks | Dash for Python Documentation (8)

Neptune Theme
Part 2. Basic Callbacks | Dash for Python Documentation (9)

Miller Theme
Part 2. Basic Callbacks | Dash for Python Documentation (10)

Extrasolar Theme
Part 2. Basic Callbacks | Dash for Python Documentation (11)

Design Kit Theme Editor
Part 2. Basic Callbacks | Dash for Python Documentation (12)

In this example, the callback executes whenever the value property of any of the
dcc.Dropdown, dcc.Slider,
or dcc.RadioItems components change.

The input arguments of the callback are the current
value of each of the “input” properties, in the order that they were
specified.

Even though only a single Input changes at a time (i.e. a user can only change
the value of a single Dropdown in a given moment), Dash collects the
current state of all the specified Input properties and passes them
into the callback function. These callback functions are always guaranteed
to receive the updated state of the app.

Let’s extend our example to include multiple outputs.

Dash App With Multiple Outputs

So far all the callbacks we’ve written only update a single Output property.
We can also update several outputs at once: list all the properties you want to update
in app.callback,
and return that many items from the callback. This is particularly useful if
two outputs depend on the same computationally intensive intermediate result,
such as a slow database query.

from dash import Dash, dcc, html, Input, Output, callbackexternal_stylesheets = ['https://codepen.io/chriddyp/pen/bWLwgP.css']app = Dash(__name__, external_stylesheets=external_stylesheets)app.layout = html.Div([ dcc.Input( id='num-multi', type='number', value=5 ), html.Table([ html.Tr([html.Td(['x', html.Sup(2)]), html.Td(id='square')]), html.Tr([html.Td(['x', html.Sup(3)]), html.Td(id='cube')]), html.Tr([html.Td([2, html.Sup('x')]), html.Td(id='twos')]), html.Tr([html.Td([3, html.Sup('x')]), html.Td(id='threes')]), html.Tr([html.Td(['x', html.Sup('x')]), html.Td(id='x^x')]), ]),])@callback( Output('square', 'children'), Output('cube', 'children'), Output('twos', 'children'), Output('threes', 'children'), Output('x^x', 'children'), Input('num-multi', 'value'))def callback_a(x): return x**2, x**3, 2**x, 3**x, x**xif __name__ == '__main__': app.run(debug=True)
x 2
x 3
2 x
3 x
x x

A word of caution: it’s not always a good idea to combine outputs, even if
you can:

  • If the outputs depend on some, but not all, of the same inputs, then keeping
    them separate can avoid unnecessary updates.
  • If the outputs have the same inputs but they perform very different computations with these
    inputs, keeping the callbacks separate can allow them to run in parallel.

Dash App With Chained Callbacks

You can also chain outputs and inputs together: the output of one callback
function could be the input of another callback function.

This pattern can be used to create dynamic UIs where, for example, one input component
updates the available options of another input component.
Here’s a simple example.

from dash import Dash, dcc, html, Input, Output, callbackexternal_stylesheets = ['https://codepen.io/chriddyp/pen/bWLwgP.css']app = Dash(__name__, external_stylesheets=external_stylesheets)all_options = { 'America': ['New York City', 'San Francisco', 'Cincinnati'], 'Canada': ['Montréal', 'Toronto', 'Ottawa']}app.layout = html.Div([ dcc.RadioItems( list(all_options.keys()), 'America', id='countries-radio', ), html.Hr(), dcc.RadioItems(id='cities-radio'), html.Hr(), html.Div(id='display-selected-values')])@callback( Output('cities-radio', 'options'), Input('countries-radio', 'value'))def set_cities_options(selected_country): return [{'label': i, 'value': i} for i in all_options[selected_country]]@callback( Output('cities-radio', 'value'), Input('cities-radio', 'options'))def set_cities_value(available_options): return available_options[0]['value']@callback( Output('display-selected-values', 'children'), Input('countries-radio', 'value'), Input('cities-radio', 'value'))def set_display_children(selected_country, selected_city): return f'{selected_city} is a city in {selected_country}'if __name__ == '__main__': app.run(debug=True)

The first callback updates the available options in the second
dcc.RadioItems component based off of the selected value in the
first dcc.RadioItems component.

The second callback sets an initial value when the options property
changes: it sets it to the first value in that options array.

The final callback displays the selected value of each component.
If you change the value of the countries dcc.RadioItems
component, Dash will wait until the value of the cities component is updated
before calling the final callback. This prevents your callbacks from being
called with inconsistent state like with "America" and "Montréal".

Dash App With State

In some cases, you might have a “form”-like pattern in your
application. In such a situation, you may want to read the value
of an input component, but only when the user is finished
entering all of their information in the form rather than immediately after
it changes.

Attaching a callback to the input values directly can look like this:

from dash import Dash, dcc, html, Input, Output, callbackexternal_stylesheets = ["https://codepen.io/chriddyp/pen/bWLwgP.css"]app = Dash(__name__, external_stylesheets=external_stylesheets)app.layout = html.Div([ dcc.Input(id="input-1", type="text", value="Montréal"), dcc.Input(id="input-2", type="text", value="Canada"), html.Div(id="number-output"),])@callback( Output("number-output", "children"), Input("input-1", "value"), Input("input-2", "value"),)def update_output(input1, input2): return f'Input 1 is "{input1}" and Input 2 is "{input2}"'if __name__ == "__main__": app.run(debug=True)

In this example, the callback function is fired whenever any of the
attributes described by the Input change.
Try it for yourself by entering data in the inputs above.

State allows you to pass along extra values without
firing the callbacks. Here’s the same example as above but with the two
dcc.Input components as State
and a new button component as an Input.

from dash import Dash, dcc, html, Input, Output, State, callbackexternal_stylesheets = ['https://codepen.io/chriddyp/pen/bWLwgP.css']app = Dash(__name__, external_stylesheets=external_stylesheets)app.layout = html.Div([ dcc.Input(id='input-1-state', type='text', value='Montréal'), dcc.Input(id='input-2-state', type='text', value='Canada'), html.Button(id='submit-button-state', n_clicks=0, children='Submit'), html.Div(id='output-state')])@callback(Output('output-state', 'children'), Input('submit-button-state', 'n_clicks'), State('input-1-state', 'value'), State('input-2-state', 'value'))def update_output(n_clicks, input1, input2): return f''' The Button has been pressed {n_clicks} times, Input 1 is "{input1}", and Input 2 is "{input2}" '''if __name__ == '__main__': app.run(debug=True)

In this example, changing text in the dcc.Input boxes won’t fire
the callback, but clicking on the button will. The current values of the
dcc.Input values are still passed into the callback even though
they don’t trigger the callback function itself.

Note that we’re triggering the callback by listening to the n_clicks property
of the html.Button component. n_clicks is a property that gets
incremented every time the component has been clicked on.
It’s available in every component in
Dash HTML Components (dash.html), but most useful with buttons.

Passing Components Into Callbacks Instead of IDs

When creating app layouts in earlier examples, we assigned IDs to components within the layout and later referenced these in callback inputs and outputs.

In the first example, there is a dcc.Input component with the id ‘my-input’ and a html.Div with the id ‘my-output’:

app.layout = html.Div([ html.H6("Change the value in the text box to see callbacks in action!"), html.Div([ "Input: ", dcc.Input(id='my-input', value='initial value', type='text') ]), html.Br(), html.Div(id='my-output'),@callback( Output('my-output', 'children'), Input('my-input', 'value'))def update_output_div(input_value): return f'Output: {input_value}'

You can also provide components directly as inputs and outputs without adding or referencing an id. Dash autogenerates IDs for these components.

Here is the first example again. Prior to declaring the app layout, we create two components, assigning each one to a variable. We then reference these variables in the layout and pass them directly as inputs and outputs to the callback.

from dash import Dash, dcc, html, Input, Output, callbackapp = Dash(__name__)my_input = dcc.Input(value='initial value', type='text')my_output = html.Div()app.layout = html.Div([ html.H6("Change the value in the text box to see callbacks in action!"), html.Div([ "Input: ", my_input ]), html.Br(), my_output])@callback( Output(my_output, 'children'), Input(my_input, 'value'))def update_output_div(input_value): return f'Output: {input_value}'if __name__ == '__main__': app.run(debug=True)

In Python 3.8 and higher, you can use the walrus operator to declare the component variables within the app layout:

app.layout = html.Div([ html.H6("Change the value in the text box to see callbacks in action!"), html.Div([ "Input: ", my_input := dcc.Input(value='initial value', type='text') ]), html.Br(), my_output := html.Div(),])@callback( Output(my_output, 'children'), Input(my_input, 'value'))def update_output_div(input_value): return f'Output: {input_value}'

Note: Auto component IDs won’t work with dynamic callback content unless the component variables are defined out of the callback scope. Additionally, they are not compatible with Pattern-Matching Callbacks.

Summary

We’ve covered the fundamentals of callbacks in Dash.
Dash apps are built off of a set
of simple but powerful principles: UIs that are customizable
through reactive callbacks.
Every attribute/property of a component can be modified
as the output of a callback, while a subset of the attributes (such as the value
property of dcc.Dropdown component)
are editable by the user through interacting with the page.

The next part of the Dash Fundamentals covers interactive graphing. Dash Fundamentals Part 3: Interactive Graphing

Part 2. Basic Callbacks | Dash for Python Documentation (2024)

FAQs

What is a callback in Dash? ›

In Dash, callbacks are defined functionality within an app that are triggered by user interaction. Specifically, a user interacts with an element which triggers a Python function, and this function will cause a change in the app. This allows us to create interactive user experiences within our apps.

Does a dash callback need output? ›

Callbacks without outputs should not return a value, because there are no outputs to update. If you return a value from the callback when there is no output to update, you'll see an error in Dash Dev Tools.

Can we add multiple input components to a Dash callback function? ›

In Dash, any "output" can have multiple "input" components. Here's a simple example that binds five inputs (the value property of two dcc.

What two functions are required to create a callback in Python? ›

A callback function is a function that is passed as an argument to another function and is “called back” at some convenient time. The function that calls the callback function is known as the “host” function and the argument (the callback) itself is known as the “guest” function.

Is callback good or bad? ›

While certainly not a guarantee you'll be cast, a callback reflects you've passed the hardest part of the audition process: making a favorable impression on the casting director. Stay true to yourself: Again, the casting director saw something they liked in your audition.

What is the purpose of a callback? ›

A callback's primary purpose is to execute code in response to an event. These events might be user-initiated, such as mouse clicks or typing. With a callback, you may instruct your application to "execute this code every time the user clicks a key on the keyboard."

Why use callback instead of function? ›

Callback functions are important in JavaScript because they let you create asynchronous code that doesn't block the main thread of execution. This enables you to perform other tasks, such as user interface (UI) updates or other API calls, while an asynchronous action is executing.

Are dash callbacks asynchronous? ›

Whether or not these requests are executed in a synchronous or asynchronous manner depends on the specific setup of the Dash back-end server. If it is running in a multi-threaded environment, then all of the callbacks can be executed simultaneously, and they will return values based on their speed of execution.

How do I prevent first callback dash? ›

According to the Dash documentation, it is possible to prevent callbacks from being executed when the app is first loaded by setting prevent_initial_call=True for specific callbacks. However, this only works if all input and output components are present in the main app layout.

What is the difference between input and state in dash callback? ›

Inputs will trigger your callback; State do not. If you need the the current “value” - aka State - of other dash components within your callback, you pass them along via State .

Can Dash have the same output in multiple callbacks? ›

If you happen to have multiple outputs that are effects of an input, then you combine those outputs in the same callback. E.g. Also, keep in mind that Dash doesn't allow multiple callbacks to have the same output component (e.g., a particular component property can be associated with one and only one callback).

What language does Plotly use? ›

Plotly is a free and open-source graphing library for Python. We recommend you read our Getting Started guide for the latest installation or upgrade instructions, then move on to our Plotly Fundamentals tutorials or dive straight in to some Basic Charts tutorials.

What is the difference between returning a callback and just calling a callback? ›

While simply calling a callback works for many scenarios, returning a callback can help you handle errors and special conditions more effectively, ensuring that your code is safe and behaves as expected.

What is simple callback function in Python? ›

In Python, a callback is simply a function or a method passed to a Hexaly Optimizer. A callback takes two parameters: the Hexaly Optimizer object that triggers the event and the type of the callback. It is possible to use the same callback method or object for multiple events or multiple Hexaly Optimizer instances.

How do you register a callback in Python? ›

Callbacks are registered/deregistered using the add_callback/del_callback methods of the VMD. vmdcallbacks module. The syntax for these methods is: def add_callback(name, func, userdata = None): def del_callback(name, func, userdata = None):

What does callback mean in shows? ›

Good, with a caveat: A callback audition means the casting director wants to see you again. But while it's a big step toward being cast, it doesn't mean you've landed the part just yet.

What is a callback for a wire? ›

A call back procedure in place to verify the customer using the predetermined PIN or password. When calling the customer back to verify the funds transfer and authenticate the transaction, the call back needs to be made to the person and phone number on the wire transfer agreement.

What is a call back in a script? ›

By definition, a callback is a dialogue technique. It's when you bring back an old line from earlier in the story. The Order of the Phoenix film has one of my favorite callbacks in it. After Harry gets detention, he has to write lines with Umbridge that say "I must not tell lies."

What is a callback recording? ›

Unique to the Multi-Line Dialer only, the Callback feature enables you to pre-record a message for the call recipient to hear if they answer the phone while you are already on a call with someone you reached via a Multi-Line Dialer session.

Top Articles
Latest Posts
Article information

Author: Tyson Zemlak

Last Updated:

Views: 5231

Rating: 4.2 / 5 (43 voted)

Reviews: 82% of readers found this page helpful

Author information

Name: Tyson Zemlak

Birthday: 1992-03-17

Address: Apt. 662 96191 Quigley Dam, Kubview, MA 42013

Phone: +441678032891

Job: Community-Services Orchestrator

Hobby: Coffee roasting, Calligraphy, Metalworking, Fashion, Vehicle restoration, Shopping, Photography

Introduction: My name is Tyson Zemlak, I am a excited, light, sparkling, super, open, fair, magnificent person who loves writing and wants to share my knowledge and understanding with you.