⚠️ Attention: This is not the latest version of the documentation.
Cross-Realm Imports
Modules in the frontend
directory of a UIX app can use exported values from modules in the backend
directory, as if they are running on the same device and within the same process.
This is accomplished with DATEX exchange between the frontend and backend endpoints.
Cross-Realm Import Example:
// file: backend/public.ts export function getData() { return [1, 2, 3]; } export const map = new Map<string, string>(); map.set("a", "Value for A");
// file: frontend/entrypoint.ts import { map, getData } from "../backend/public.ts"; console.log(map); // Map {"a"->"Value for A"} console.log(await getData()); // [1,2,3]
Warning
Because network requests are asynchronous, imported functions always return a Promise
that must be awaited.
For the same reason, all value updates are propagated asynchronously between endpoints.
Common Modules
Modules from the common directory can be imported from both the backend and frontend.
This is useful for definining components that can be rendered by the backend or frontend, or for utility functions or libraries that are used on the backend and frontend.
Note
Common modules allow the usage of the same source code for the backend and frontend, but they do not share a state between the backend and frontend endpoints: Every module is initialized individually on each endpoint. A shared module state is only possible with backend modules imported from the backend and frontend.
Security
Only values that are explicitly imported in frontend module source code are publicly exposed from the backend. All of the other exports are still only accessible within the backend context.
Even if values are exported from the backend because they are required on the frontend, the backend module source code is never publicly exposed - only the exported values are accessible.
Help us improving our docs
Our documentations are fully open source. Something is wrong or unclear?