WebAssembly增强前端应用技巧详解

目录
准备开始创建项目打包 wasm前端调用使用 console.log总结

准备

此篇文章我们主要使用 Rust 来编写我们的 WebAssembly 工具库然后在 React 应用进行使用。所以需要准备好下列的环境

Rust 开发环境(rustup、rustc、cargo 这些)前端开发环境(node、npm 这些)wasm-pack (cargo install wasm-pack)

开始

开始前我们先要准备一个前端应用,这里我们使用 create-react-app来创建一个 React 项目。 如果没有安装 create-react-app,先用 pnpm (npm / yarn 也行)全局安装一下


(资料图片)

npm install -g create-react-app

创建项目

使用 typescript 模板来创建项目,以获得更好的类型提示。

create-react-app react-wasm --template typescript

进入到刚创建好的项目目录中

cd react-wasm

创建好 react 项目之后,我们接下来使用 wasm-pack 创建一个 wasm 工具库

wasm-pack new wasm-lib

创建完成后我们的目录结构是像下面这样子的,

src目录主要编写前端应用代码

wasm-lib/src目录主要编写 rust wasm 代码

wasm-lib/src/lib.rs目录下,这里就是我们可以进行编写供前端调用的 WebAssembly 函数。这里默认写好了一个 greet 函数,然后里面调用了 alert 弹框。接下来我们就去看看如何在前端中进行使用这个函数。

mod utils;
use wasm_bindgen::prelude::*;
// 当 `wee_alloc` 特性开启的时候, 使用 `wee_alloc` 作为全局分配器
#[cfg(feature = "wee_alloc")]
#[global_allocator]
static ALLOC: wee_alloc::WeeAlloc = wee_alloc::WeeAlloc::INIT;
#[wasm_bindgen]
extern "C" {
    fn alert(s: &str);
}
#[wasm_bindgen]
pub fn greet() {
    alert("Hello, wasm-lib!");
}

打包 wasm

在 package.json 文件中添加这一行代码,然后我们就可以进行打包了。

项目根目录中运行

npm run build:wasm

如果在 build 的过程卡住了,或者报错了。可以先暂时把代码优化给关闭掉

在 wasm-lib 目录下的 Cargo.toml配置文件中关掉 wasm-opt

打包完成后就能看到项目根目录中出现了一个 pkg 文件夹,这里面就是我们打包后的产物,前端可以进行调用我们用 Rust 编写的函数。

前端调用

我们有两种方式去调用 pkg 目录下的 wasm 函数:

一种是将 pkg 作为一个 npm 包发布

cd wasm-lib
# 该命令可以把这个库作为 npm 包发布到 npm 中,然后我们前端就正常的方式 npm install 就可以使用了
wasm-pack publish

另一种是先在本地进行引用,根目录下安装

npm install ./pkg

然后 package.json 的依赖中增加了我们的本地库:

{
  "name": "react-wasm",
  "version": "0.1.0",
  "private": true,
  "dependencies": {
    "@testing-library/jest-dom": "^5.16.4",
    "@testing-library/react": "^13.3.0",
    "@testing-library/user-event": "^13.5.0",
    "@types/jest": "^27.5.1",
    "@types/node": "^16.11.36",
    "@types/react": "^18.0.9",
    "@types/react-dom": "^18.0.5",
    "react": "^18.1.0",
    "react-dom": "^18.1.0",
    "react-scripts": "5.0.1",
    "typescript": "^4.7.2",
    "wasm-lib": "file:pkg", // ++++++++++++++++++++++++++++
    "web-vitals": "^2.1.4"
  },
  // ...
}

接下来就去我们的 App.tsx 中调用 greet 方法:

import React, { useEffect } from "react";
import init, { greet } from "wasm-lib";
import logo from "./logo.svg";
import "./App.css";
function App() {
  // +++++++++++++++++
  useEffect(() => {
    init().then(() => {
      greet();
    });
  }, []);
  return (
    
...
); } export default App;

然后开始运行我们的 react 应用

npm run start

打开 localhost:3000 端口,可以看到我们调用 alert 方法成功咯~

使用 console.log

首先我们要安装一下 web-sys 这个包,在 Cargo.toml 中加入

[dependencies]
wasm-bindgen = "0.2.63"
web-sys = { version = "0.3.57", features = ["console"] } # ++++++++

在这里我们开启了 console 这个 feature, web-sys 还支持很多 feature,比如可以操作 DOM,调用前端原生 fetch API , 操作 Canvas , WebGL 等等等。

Rust:

mod utils;
use web_sys::console;
use wasm_bindgen::prelude::*;
#[cfg(feature = "wee_alloc")]
#[global_allocator]
static ALLOC: wee_alloc::WeeAlloc = wee_alloc::WeeAlloc::INIT;
#[wasm_bindgen]
pub fn test_log(val: JsValue) {
    console::log_2(&"从JS端接受到数据".into(), &val);
}

JS:

import React, { useEffect } from "react";
import init, { test_log } from "wasm-lib";
import logo from "./logo.svg";
import "./App.css";
function App() {
  useEffect(() => {
    init().then(() => {
      test_log({ a: 1, b: 2, c: 3 });
    });
  }, []);
  return (
    
...
); } export default App;

打印结果:

总结

像一些复杂的计算,我们可以使用 WebAssembly 来进行操作,比如上一篇。 WebAssembly 目前论开发效率来说个人感觉是不如原生 JS 的,稍微有点繁琐,目前感觉它的应用场景更多是在复杂性的计算领域,比如写游戏、音视频解析、加密解密、图片解析等这种需要复杂计算的。这里只是提供一个基础的小demo,让大家对这个东西有一个感性的了解,更深入的东西就得后面用到的时候再去了解了。

最后这里放上 官方参考文档

以上就是WebAssembly增强前端应用技巧详解的详细内容,更多关于WebAssembly增强前端应用的资料请关注脚本之家其它相关文章!

关键词:

为您推荐

WebAssembly增强前端应用技巧详解

这篇文章主要为大家介绍了WebAssembly增强前端应用技巧示例详解,有需

来源:脚本之家2023-07-30

记者实地探访|石家庄体育北大街与古城东路整个交口全部积水,情况严重

河北新闻网7月30日讯(燕赵都市报纵览新闻记者张超)今日13时,燕赵都

来源:河北新闻网2023-07-30

尤文图斯舞王,加拿大女足版毕加索细腻的中场,灵动...

尤文图斯舞王,加拿大女足版毕加索细腻的中场,灵动的脚部,优雅的身姿

来源:懂球帝 2023-07-30

王阳的老婆叫什么,相守十余年为其生下女儿

王阳的妻子叫高斯,也是名演员,两人携手共度十多年,感情依旧甜蜜幸福

来源:互联网2023-07-30

侍怎么组词(轼怎么组词)

【组词】:转轼,茵轼,熊轼,轼柜,凭轼,泥轼,据轼,回轼,横轼,伏

来源:互联网2023-07-30

“全球重要农业文化遗产”龙脊梯田稻浪青绿如画

(杨宗盛)盛夏时节,广西桂林市龙胜各族自治县龙脊镇金坑大寨梯田的禾

来源:中国新闻网2023-07-30

民柬成立宣言 关于民柬成立宣言介绍

1、民柬成立宣言。2、由1982年6月22日柬埔寨爱国力量三方领导人西哈努

来源:互联网2023-07-30

自汉武帝开始南下归汉的匈奴,后来怎样了?怎么没有他们的踪迹了

建于汉武帝时期的阳关烽燧在中国的历史上,匈奴曾经十分强盛,对中原虎

来源:腾讯网2023-07-30