Skip to content

Latest commit

 

History

History
74 lines (45 loc) · 6.65 KB

ServerSideRendering.md

File metadata and controls

74 lines (45 loc) · 6.65 KB
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.

How to integrate this API into your website or application

A typical sequence of events would be:

  1. A user makes a request to your server to open your website, which includes an embedded notebook.
  2. 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.
  3. 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.
  4. 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).

Parameters

Waiting for HTML to be available using maxwaitmillis

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.

Specifying a notebook width using width

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.

Only including limited cell content using limitcontent

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.