ui.page_fluid(
ui.head_content(ui.include_js("custom.js")),
)
# Alternately you can inline Javscript by changing the method.
ui.page_fluid(
ui.head_content(ui.include_js("custom.js", method = "inline")),
)express.ui.include_js
express.ui.include_js(path, *, method='link', **kwargs)Include a JavaScript file.
Parameters
path : Path | str-
A path to a JS file.
method : Literal[‘link’, ‘link_files’, ‘inline’] = 'link'-
One of the following: *
"link"is the link to the CSS file via alinktag. This method is generally preferable to"inline"since it allows the browser to cache the file. *"link_files"is the same as"link", but also allow for the CSS file to request other files withinpath‘s immediate parent directory (e.g.,@import()another file). Note that this isn’t the default behavior because you should be careful not to include files in the same directory aspaththat contain sensitive information. A good general rule of thumb to follow is to havepathbe located in a subdirectory of the app directory. For example, if the app’s source is located at/app/app.py, thenpathshould be somewhere like/app/css/custom.css(and all the other relevant accompanying ’safe’ files should be located under/app/css/). *"inline"is the inline the CSS file contents within astyletag. ****kwargs** : TagAttrValue = {}-
Attributes which are passed on to
~shiny.express.ui.tags.script.
Returns
: Tag-
A
scripttag.
Note
This places a script tag in the body of the document. If you want to place the tag in the head of the document instead, you can wrap it in head_content (in this case, just make sure you’re aware that the DOM probably won’t be ready when the script is executed).
See Also
script- include_css
Examples
#| '!! shinylive warning !!': |
#| shinylive does not work in self-contained HTML documents.
#| Please set `embed-resources: false` in your metadata.
#| standalone: true
#| components: [editor, viewer]
#| layout: vertical
#| viewerHeight: 400
## file: app.py
from pathlib import Path
from shiny.express import ui
js_file = Path(__file__).parent / "js" / "app.js"
"If you see this page before 'OK'-ing the alert box, something went wrong"
ui.include_js(js_file)
## file: js/app.js
alert("If you're seeing this, the javascript file was included successfully.");