Crates.io | stylist |
lib.rs | stylist |
version | 0.13.0 |
source | src |
created_at | 2021-08-02 15:30:51.869032 |
updated_at | 2023-10-06 14:09:57.644624 |
description | Stylist is a CSS-in-Rust styling solution for WebAssembly Applications. |
homepage | https://github.com/futursolo/stylist-rs |
repository | https://github.com/futursolo/stylist-rs |
max_upload_size | |
id | 430485 |
size | 85,894 |
Stylist is a CSS-in-Rust styling solution for WebAssembly Applications.
This is a fork of css-in-rust.
Add the following to your Cargo.toml
:
stylist = "0.13"
For detailed usage, please see documentation.
To style your component, you can use styled_component
attribute with css!
macro.
use yew::prelude::*;
use stylist::yew::styled_component;
#[styled_component]
fn MyStyledComponent() -> Html {
html! {<div class={css!("color: red;")}>{"Hello World!"}</div>}
}
To create a stylesheet, you can use style!
:
use stylist::style;
let style = style!(
// A CSS string literal
r#"
background-color: red;
.nested {
background-color: blue;
width: 100px
}
"#
).expect("Failed to mount style");
// stylist-uSu9NZZu
println!("{}", style.get_class_name());
If you want to parse a string into a style at runtime, you can use Style::new
:
use stylist::Style;
let style_str = r#"
background-color: red;
.nested {
background-color: blue;
width: 100px
}
"#;
let style = Style::new(style_str).expect("Failed to create style");
// stylist-uSu9NZZu
println!("{}", style.get_class_name());
There's theming example using Yew Context API.