mirror of
https://github.com/DioxusLabs/dioxus
synced 2024-11-21 19:53:04 +00:00
95976d9a17
* Fix hot reloading components with keys * include component formatted segment keys, but not dynamic component value * extend each head component with the corresponding element * Allow spreading custom attributes into components * Fix component_literal_dyn_idx index * add a new test for hot reloading components with keys * FIx script without body warning and rendering styles with a href set * fix clippy
43 lines
1.1 KiB
Rust
43 lines
1.1 KiB
Rust
//! This example demonstrates how to use the spread operator to pass attributes to child components.
|
|
//!
|
|
//! This lets components like the `Link` allow the user to extend the attributes of the underlying `a` tag.
|
|
//! These attributes are bundled into a `Vec<Attribute>` which can be spread into the child component using the `..` operator.
|
|
|
|
use dioxus::prelude::*;
|
|
|
|
fn main() {
|
|
let dom = VirtualDom::prebuilt(app);
|
|
let html = dioxus_ssr::render(&dom);
|
|
|
|
println!("{}", html);
|
|
}
|
|
|
|
fn app() -> Element {
|
|
rsx! {
|
|
SpreadableComponent {
|
|
width: "10px",
|
|
extra_data: "hello{1}",
|
|
extra_data2: "hello{2}",
|
|
height: "10px",
|
|
left: 1,
|
|
"data-custom-attribute": "value",
|
|
}
|
|
}
|
|
}
|
|
|
|
#[derive(Props, PartialEq, Clone)]
|
|
struct Props {
|
|
#[props(extends = GlobalAttributes)]
|
|
attributes: Vec<Attribute>,
|
|
|
|
extra_data: String,
|
|
|
|
extra_data2: String,
|
|
}
|
|
|
|
#[component]
|
|
fn SpreadableComponent(props: Props) -> Element {
|
|
rsx! {
|
|
audio { ..props.attributes, "1: {props.extra_data}\n2: {props.extra_data2}" }
|
|
}
|
|
}
|