id | title |
---|---|
ServerSideRendering |
Server-Side Rendering |
In some cases, you might want to include (static) HTML for a notebook on the HTML page rendered by your server so it can be shown even before the necessary JavaScript code is loaded and executed. This reduces the time until the user sees the notebook, and it also helps search engines to index your notebook content. Once your JavaScript code executes, you can use the function WolframNotebookEmbedder.embed as usual to embed the notebook into the same container node, and it will transition seamlessly from the static view to "live" (interactive) rendering. The same happens on wolframcloud.com as well.
Static HTML is generated ("pre-rendered") for each cloud notebook whenever it is created or changed. You can access it through an HTTP API, by making a GET
request to
https://www.wolframcloud.com/statichtml/{path}
where {path}
is the notebook's cloud object path, which might be a UUID (e.g. 4beadfbb-84dd-4b26-87b6-bcd30b9abd65
for a cloud object at https://www.wolframcloud.com/obj/4beadfbb-84dd-4b26-87b6-bcd30b9abd65
) or a user base URL + folder/file name (e.g. myname/foo/bar.nb
for a cloud object at https://www.wolframcloud.com/obj/myname/foo/bar.nb
).
This API returns a piece of static HTML that can be included right on your page by your server-side code. You might want to cache the response from the /statichtml
API on your server, so you don't have to request it whenever a user visits your website.
A typical sequence of events would be:
- A user makes a request to your server to open your website, which includes an embedded notebook.
- Your server makes a request to
https://www.wolframcloud.com/statichtml/{path}
to fetch the static HTML for the embedded notebook, or it uses an existing cache for that static HTML. - Your server returns an HTML page to the user, which includes the static HTML of the notebook inside the HTML element where the notebook is supposed to be embedded.
- In your JavaScript code, you call
WolframNotebookEmbedder.embed
to embed the notebook into the same HTML element, which causes the notebook to "live-render" on the client side. See Notebook Loading Phases for more information about what happens then.
To summarize:
Wolfram Cloud
^ |
| | static HTML for notebook
/statichtml API | |
| v
Your server
^ |
| | your website including static notebook HTML
request | | and JS code using WolframNotebookEmbedder
| v
User of your website
If you do not have active code running on your server but just a static HTML page, you could also use this API to generate HTML for the notebook once and then include that right in your static HTML. The downsides of this approach are that the HTML will not automatically update if the notebook is changed, and it will not be kept in sync with newer Wolfram Cloud versions (potentially resulting in rendering inconsistencies).
Sometimes, there might be no HTML for a notebook available yet, e.g. when it has just been edited and the cloud server has not had a chance to pre-render it yet. In that case, the API will return an empty response. However, you can tell the API to wait up to a certain time and return static HTML once it becomes available. That's what the query parameter maxwaitmillis
is for, e.g.
https://www.wolframcloud.com/statichtml/4beadfbb-84dd-4b26-87b6-bcd30b9abd65?maxwaitmillis=500
would wait up to 500 milliseconds in case there is no HTML available yet and return once it becomes available. If the cloud server has not finished generating HTML after half a second, the API will return an empty response.
The maximum accepted value for maxwaitmillis
is 20,000 (20 seconds). Typically, using rather low values (not longer than 1 second) is recommended, since this would delay the initial response from your server (while it is waiting for the cloud server to return HTML) and thus the loading of the whole page.
Parts of the static HTML might depend on the page width, e.g. to determine where to line-wrap code cells. Since the page width is not usually known on the server, it can only assume a certain notebook width and return HTML for that, which will cause text to reflow on the client side (once the actual page width is known and "live" rendering kicks in). If you do know the notebook width in advance (e.g. because you are embedding the notebook at a fixed width), you can request HTML for that particular width using the width
parameter to the API, e.g.
https://www.wolframcloud.com/statichtml/4beadfbb-84dd-4b26-87b6-bcd30b9abd65?width=700
would request HTML for a notebook width of 700 pixels. There is no guarantee that you get HTML for exactly that width, but the API will choose the best match out of the available pre-rendered HTML.
By default, the content of all visible cells in the notebook is included in the returned static HTML. This is usually fine if the notebook is not too long and is shown in its entirety on the embedding website anyway.
However, it can be a significant overhead for long notebooks, both in terms of assembling the static HTML on the cloud server (resulting in a longer response time for the /statichtml
API) and in terms of longer download times for the client (resulting in a longer time to first paint for the viewer). To address this, you can set the parameter limitcontent=true
to limit the content that is included in the static HTML.
If this parameter is set to true
, only cells "above the fold" (i.e. vertically within a few thousand pixels from the notebook start) are included, plus some other simple, textual cells that do not increase the overall size of the static HTML by much. Other cells are only included as empty placeholders. At the bottom of the notebook (below any non-placeholder cell), a special background is used to indicate that the content there is no available (yet).
Once client-side rendering of the notebook starts, the static HTML for all placeholder cells will be fetched asynchronously, which is used until the client-side rendering of each cell completes.
This limited initial static HTML is what effectively happens for notebooks on wolframcloud.com.
This parameter is introduced in Cloud 1.56.