【Rust每周一库】Yew - Rust语言实现的WebAssembly多线程前端框架
本期的每周一库带来的是一个Rust下的WebAssembly多线程前端框架Yew
相关链接
-  
   
Yew Github仓库  -  
   
Yew中文文档  
Yew是一个设计先进的Rust前端框架,目的是使用WebAssembly来创建多线程前端web应用。
Yew的主要特性包括
-  
   
基于组件的框架  -  
   
高性能  -  
   
支持与Javascript交互  
下面我们结合Yew官方文档来创建一个简单的Web App并在本地预览。
为了能够在本地预览通过Yew实现的Web App,我们首先要选择一个Wasm构建工具,构建工具可以方便WebAssembly和JavaScript交互。从而减轻了部署和打包工程的复杂度。
Yew文档中介绍了三种Wasm构建工具
-  
   
wasm-pack -  
   
wasm-bindgen -  
   
cargo-web 
这里我们选择相对简单并且兼容性更好的cargo-web构建工具。
安装cargo-web
我们可以使用如下命令来安装cargo-web构建工具,安装时间大约2mins
cargo install cargo-web 
 第一个简单的Web App
这里参考Yew文档中的第一个简单的App章节来进行实验
首先创建一个rust工程
cargo new --bin hello-yew 
 然后在Cargo.toml文件中添加Yew依赖
[dependencies]yew = { version = "0.14.3", features = ["std_web"] }
修改src/main.rs代码
use yew::prelude::*;struct Model {link: ComponentLink<Self>,value: i64,}enum Msg {AddOne,}impl Component for Model {type Message = Msg;type Properties = ();fn create(_: Self::Properties, link: ComponentLink<Self>) -> Self {Self {link,value: 0,}}fn update(&mut self, msg: Self::Message) -> ShouldRender {match msg {Msg::AddOne => self.value += 1}true // 指示组件应该重新渲染}fn view(&self) -> Html {html! {<div><h1>{"Hello Yew"}</h1><button onclick=self.link.callback(|_| Msg::AddOne)>{ "+1" }</button><p>{ self.value }</p></div>}}}fn main() {yew::initialize();App::<Model>::new().mount_to_body();}
运行程序
在工程文件夹根目录运行命令
cargo web start 
 Yew文档内容十分详细,文档中紧接着就解释了Cargo.toml文件中通过不同的方式来构建应用的讲解,可以点击左下角原文链接查看Yew中文文档来继续深入。
