Hub documentation

How to handle URL parameters in Spaces

Hugging Face's logo
Join the Hugging Face community

and get access to the augmented documentation experience

to get started

How to handle URL parameters in Spaces

You can use URL query parameters as a data sharing mechanism, for instance to be able to deep-link into an app with a specific state.

On a Space page (https://huggingface.co/spaces/<user>/<app>), the actual application page (https://*.hf.space/) is embedded in an iframe. The query string and the hash attached to the parent page URL are propagated to the embedded app on initial load, so the embedded app can read these values without special consideration.

In contrast, updating the query string and the hash of the parent page URL from the embedded app is slightly more complex. If you want to do this in a Docker or static Space, you need to add the following JS code that sends a message to the parent page that has a queryString and/or hash key.

const queryString = "...";
const hash = "...";

window.parent.postMessage({
    queryString,
    hash,
}, "https://huggingface.co");

This is only for Docker or static Spaces.

For Streamlit apps, Spaces automatically syncs the URL parameters. Gradio apps can read the query parameters from the Spaces page, but do not sync updated URL parameters with the parent page.

Note that the URL parameters of the parent page are propagated to the embedded app only on the initial load. So location.hash in the embedded app will not change even if the parent URL hash is updated using this method.

An example of this method can be found in this static Space, whitphx/static-url-param-sync-example.

< > Update on GitHub