2024-02-14 20:33:07 +00:00
|
|
|
//! Dioxus allows webcomponents to be created with a simple syntax.
|
|
|
|
//!
|
|
|
|
//! Read more about webcomponents [here](https://developer.mozilla.org/en-US/docs/Web/Web_Components)
|
|
|
|
//!
|
|
|
|
//! We typically suggest wrapping webcomponents in a strongly typed interface using a component.
|
|
|
|
|
2023-03-20 01:37:40 +00:00
|
|
|
use dioxus::prelude::*;
|
|
|
|
|
|
|
|
fn main() {
|
2024-10-10 23:00:58 +00:00
|
|
|
dioxus::launch(app);
|
2023-03-20 01:37:40 +00:00
|
|
|
}
|
|
|
|
|
2024-01-14 04:51:37 +00:00
|
|
|
fn app() -> Element {
|
2024-01-16 19:18:46 +00:00
|
|
|
rsx! {
|
2024-02-14 20:33:07 +00:00
|
|
|
div {
|
|
|
|
h1 { "Web Components" }
|
2024-07-24 00:49:33 +00:00
|
|
|
CoolWebComponent { my_prop: "Hello, world!".to_string() }
|
2024-02-14 20:33:07 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/// A web-component wrapped with a strongly typed interface using a component
|
|
|
|
#[component]
|
2024-07-24 00:49:33 +00:00
|
|
|
fn CoolWebComponent(my_prop: String) -> Element {
|
2024-02-14 20:33:07 +00:00
|
|
|
rsx! {
|
|
|
|
// rsx! takes a webcomponent as long as its tag name is separated with dashes
|
2023-03-20 01:37:40 +00:00
|
|
|
web-component {
|
2024-02-14 20:33:07 +00:00
|
|
|
// Since web-components don't have built-in attributes, the attribute names must be passed as a string
|
|
|
|
"my-prop": my_prop,
|
2023-03-20 01:37:40 +00:00
|
|
|
}
|
2024-01-14 05:12:21 +00:00
|
|
|
}
|
2023-03-20 01:37:40 +00:00
|
|
|
}
|