首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >【Rust每周一库】Yew - Rust语言实现的WebAssembly多线程前端框架

【Rust每周一库】Yew - Rust语言实现的WebAssembly多线程前端框架

作者头像
MikeLoveRust
发布2020-05-22 17:00:29
1.4K0
发布2020-05-22 17:00:29
举报

本期的每周一库带来的是一个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

首次运行会进行compile,然后可以使用浏览器在默认地址localhost:8000访问我们刚才创建的Yew工程

Yew文档内容十分详细,文档中紧接着就解释了Cargo.toml文件中通过不同的方式来构建应用的讲解

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2020-05-15,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 Rust语言学习交流 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档