温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

Rust语言中怎么实现一个WebAssembly多线程前端框架

发布时间:2021-08-09 11:59:36 来源:亿速云 阅读:562 作者:Leah 栏目:大数据

Rust语言中怎么实现一个WebAssembly多线程前端框架,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。


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>                <h2>{"Hello Yew"}</h2>                <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工程

Rust语言中怎么实现一个WebAssembly多线程前端框架


关于Rust语言中怎么实现一个WebAssembly多线程前端框架问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注亿速云行业资讯频道了解更多相关知识。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI