mirror of
https://github.com/DioxusLabs/dioxus
synced 2024-12-18 08:33:07 +00:00
146 lines
3.4 KiB
Markdown
146 lines
3.4 KiB
Markdown
# Examples
|
||
|
||
These examples are fully-fledged mini Dioxus apps.
|
||
|
||
You can run them with `cargo run --example EXAMPLE_NAME`. Example:
|
||
|
||
```shell
|
||
cargo run --example hello_world
|
||
```
|
||
|
||
(Most of these examples are run through webview, so you don't need the Dioxus CLI installed)
|
||
|
||
## Basic Features
|
||
|
||
[hello_world](./hello_world.rs) - Most basic example
|
||
|
||
[readme](./readme.rs) - Counter example from the Readme
|
||
|
||
[custom_assets](./custom_assets.rs) - Include images
|
||
|
||
[custom_html](./custom_html.rs) - Customize wrapper HTML
|
||
|
||
[eval](./eval.rs) - Evaluate JS expressions
|
||
|
||
### RSX
|
||
|
||
[rsx_usage](./rsx_usage.rs) - Demo of all RSX features
|
||
|
||
[xss_safety](./xss_safety.rs) - You can include text without worrying about injections by default
|
||
|
||
### Props
|
||
|
||
[borrowed](./borrowed.rs) - Borrowed props
|
||
|
||
[inlineprops](./inlineprops.rs) - Demo of `inline_props` macro
|
||
|
||
[optional_props](./optional_props.rs) - Optional props
|
||
|
||
### CSS
|
||
|
||
[all_css](./all_css.rs) - You can specify any CSS attribute
|
||
|
||
[tailwind](./tailwind.rs) - You can use a library for styling
|
||
|
||
## Input Handling
|
||
|
||
[all_events](./all_events.rs) - Basic event handling demo
|
||
|
||
[filedragdrop](./filedragdrop.rs) - Handle dropped files
|
||
|
||
[form](./form.rs) - Handle form submission
|
||
|
||
[inputs](./inputs.rs) - Input values
|
||
|
||
[nested_listeners](./nested_listeners.rs) - Nested handlers and bubbling
|
||
|
||
[textarea](textarea.rs) - Text area input
|
||
|
||
### State Management
|
||
|
||
[fermi](./fermi.rs) - Fermi library for state management
|
||
|
||
[pattern_reducer](./pattern_reducer.rs) - The reducer pattern with `use_state`
|
||
|
||
[rsx_compile_fail](./rsx_compile_fail.rs)
|
||
|
||
### Async
|
||
|
||
[login_form](./login_form.rs) - Login endpoint example
|
||
|
||
[suspense](./suspense.rs) - Render placeholders while data is loading
|
||
|
||
[tasks](./tasks.rs) - Continuously run future
|
||
|
||
### SVG
|
||
|
||
[svg_basic](./svg_basic.rs)
|
||
|
||
[svg](./svg.rs)
|
||
|
||
### Performance
|
||
|
||
[framework_benchmark](./framework_benchmark.rs) - Renders a huge list
|
||
|
||
> Note: The benchmark should be run in release mode:
|
||
>
|
||
>```shell
|
||
> cargo run --example framework_benchmark --release
|
||
>```
|
||
|
||
[heavy_compute](./heavy_compute.rs) - How to deal with expensive operations
|
||
|
||
## Server-side rendering
|
||
|
||
[ssr](./ssr.rs) - Rendering RSX server-side
|
||
|
||
[hydration](./hydration.rs) - Pre-rendering with hydration
|
||
|
||
## Common Patterns
|
||
|
||
[disabled](./disabled.rs) - Disable buttons conditionally
|
||
|
||
[error_handle](./error_handle.rs) - Handle errors with early return
|
||
|
||
## Routing
|
||
|
||
[flat_router](./flat_router.rs) - Basic, flat route example
|
||
|
||
[router](./router.rs) - Router example
|
||
|
||
[link](./link.rs) - Internal, external and custom links
|
||
|
||
## Platform Features
|
||
|
||
[window_event](./window_event.rs) - Window decorations, fullscreen, minimization, etc.
|
||
|
||
[window_zoom](./window_zoom.rs) – Zoom in or out
|
||
|
||
## Example Apps
|
||
|
||
[calculator](./calculator.rs) - Simple calculator
|
||
|
||
[pattern_model](./pattern_model.rs) - Simple calculator, but using a custom struct as the model
|
||
|
||
[crm](./crm.rs) - Toy multi-page customer management app
|
||
|
||
[dog_app](./dog_app.rs) - Accesses dog API
|
||
|
||
[file_explorer](./file_explorer.rs) - File browser that uses `use_ref` to interact with the model
|
||
|
||
[todomvc](./todomvc.rs) - Todo task list example
|
||
|
||
# TODO
|
||
Missing Features
|
||
- Fine-grained reactivity
|
||
- Refs - imperative handles to elements
|
||
- Function-driven children: Pass functions to make VNodes
|
||
|
||
Missing examples
|
||
- Shared state
|
||
- Root-less element groups
|
||
- Spread props
|
||
- Custom elements
|
||
- Component Children: Pass children into child components
|
||
- Render To string: Render a mounted virtualdom to a string
|
||
- Testing and Debugging
|