2 个版本
0.1.1 | 2024 年 1 月 17 日 |
---|---|
0.1.0 | 2024 年 1 月 6 日 |
#255 在 模板引擎 中
15KB
421 行
hyped
hyped 提供了一种从纯 Rust 函数中渲染 HTML 的直观方法
cargo add hyped
编写一些 HTML
use hyped::*;
fn render_to_string(element: Element) -> String {
render((
doctype(),
html((
head((title("title"), meta().charset("utf-8"))),
body(element)
))
))
}
#[cfg(test)]
mod tests {
#[test]
fn it_works() {
assert_eq!(
render_to_string(div("hyped")),
"<!DOCTYPE html><html><head><title>title</title></head><body><div>hyped</div></body></html>"
)
}
}
自定义属性
use hyped::*;
fn htmx_input() -> Element {
input()
.attr("hx-post", "/")
.attr("hx-target", ".target")
.attr("hx-swap", "outerHTML")
.attr("hx-push-url", "false")
}
fn main() {
let html: String = render(htmx_input());
// html == <input hx-post="/" hx-target=".target" hx-swap="outerHTML" hx-push-url="false">
}
自定义元素
use hyped::*;
fn turbo_frame(children: Element) -> Element {
element("turbo-frame", children)
}
fn main() {
let html: String = render(turbo_frame(div("inside turbo frame")).id("id"));
// html ==
// <turbo-frame id="id">
// <div>inside turbo frame</div>
// </turbo-frame>
}