免费观看又色又爽又黄的小说免费_美女福利视频国产片_亚洲欧美精品_美国一级大黄大色毛片

Rust語言中怎么實現一個WebAssembly多線程前端框架

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多線程前端框架問題的解答就分享到這里了,希望以上內容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關注創新互聯行業資訊頻道了解更多相關知識。

文章標題:Rust語言中怎么實現一個WebAssembly多線程前端框架
URL地址:http://m.newbst.com/article38/jegdpp.html

成都網站建設公司_創新互聯,為您提供營銷型網站建設網站排名移動網站建設服務器托管軟件開發

廣告

聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯

成都做網站