Access and Manipulate the URL#

This guide addresses how to access and manipulate the URL.

This powerful technique enables you to save the state of your app via the url. You can bookmark the URL or share the URL with friends or colleagues to open the app in the exact same state later.

Access#

When starting a server session Panel will attach a Location component which can be accessed using pn.state.location. The Location component serves a number of functions:

  • Navigation between pages via pathname

  • Sharing (parts of) the page state in the url as search parameters for bookmarking and sharing.

  • Navigating to subsections of the page via the hash_ parameter.

Core#

  • pathname (string): pathname part of the url, e.g. ‘/how_to/layout/spacing.html’.

  • search (string): search part of the url e.g. ‘?color=blue’.

  • hash_ (string): hash part of the url e.g. ‘#margin-parameter’.

  • reload (bool): Whether or not to reload the page when the url is updated.

    • For independent apps this should be set to True.

    • For integrated or single page apps this should be set to False.

Readonly#

  • href (string): The full url, e.g. ‘https://panel.holoviz.org:443/how_to/layout/spacing.html?color=blue#margin-parameter’.

  • protocol (string): protocol part of the url, e.g. ‘http:’ or ‘https:’

  • port (string): port number, e.g. ‘80’

Note

In a notebook environment pn.state.location is not initialized until the first plot has been displayed

Manipulate#

By default the current query parameters in the URL (specified as a URL suffix such as ?color=blue) are made available on pn.state.location.query_params.

Sync and Unsync#

To make working with query parameters straightforward the Location object provides a sync method which allows syncing query parameters with the parameters on a Parameterized object.

We will start by defining a Parameterized class:

import panel as pn
import param


class Settings(param.Parameterized):
    integer = param.Integer(default=1, bounds=(0, 10))
    string = param.String(default='A string')

    dont_sync = param.String(default='A string')

Now we will use the pn.state.location object to sync it with the URL query string. The sync method takes the Parameterized class or instance to sync with as the first argument and a list or dictionary of the parameters as the second argument. If a dictionary is provided it should map from the Parameterized object’s parameters to the query parameter name in the URL:

settings = Settings()

pn.state.location.sync(settings, {'integer': 'int', 'string': 'str'})

Now the Parameterized object is bi-directionally linked to the URL query parameter.

Lets try to serve it as an app

pn.Param(settings).servable()

Note to unsync the Parameterized object you can simply call pn.state.location.unsync(query_example).