Calling JavaScript from the Server
The Element API contains methods for executing JavaScript in the browser from the server side.
callJsFunction Method
The Element.callJsFunction() method allows you to run a client-side component function from the server side. The method accepts two parameters: the name of the function to call; and the arguments to pass to the function.
The arguments passed to the function must be a type supported by the communication mechanism. The supported types are String, Boolean, Integer, Double, JsonValue, Element, and Component.
clearSelection() JavaScript function on the root element from the server sideSource code
Java
public void clearSelection() {
getElement().callJsFunction("clearSelection");
}expand(otherComponentElement) JavaScript function on the root element from the server sideSource code
Java
public void setExpanded(Component otherComponent) {
getElement().callJsFunction("expand",
otherComponent.getElement());
}executeJs Method
You can also use the generic Element.executeJs() method to run JavaScript asynchronously from the server side. This method can be used in addition to the Element.callJsFunction() method when calling any JavaScript.
The executeJs() method accepts two parameters: the JavaScript expression to invoke; and the parameters to pass to the expression. The given parameters are available as variables named $0, $1, and so on.
The arguments passed to the expression must be a type supported by the communication mechanism. The supported types are String, Integer, Double, Boolean and Element.
MyModule.complete(true) on the client sideSource code
Java
public void complete() {
getElement().executeJs("MyModule.complete($0)", true);
}|
Warning
|
Avoid Script Injection Vulnerabilities
Always pass arguments using the $0, $1, … notation to avoid script injection vulnerabilities. Never concatenate or interpolate strings to build JavaScript code to be executed.
|
If you need to run JavaScript without having access to an element, use the UI.getCurrent().getPage().executeJs() method.
Return Values
The return value from the JavaScript function called using callJsFunction(), or the value from a return statement in an executeJs() expression can be accessed by adding a listener to the PendingJavaScriptResult instance returned from either method.
Source code
Java
public void checkConstructableStylesheets() {
getElement().executeJs(
"return 'adoptedStyleSheets' in document")
.then(Boolean.class, supported -> {
if (supported) {
System.out.println(
"Feature is supported");
} else {
System.out.println(
"Feature isn't supported");
}
});
}If the return value is a JavaScript Promise, the client only sends the return value to the server when the Promise is resolved.
AB7EDF45-DB22-4560-AF27-FF1DC6944482