javascript - 从 Wasm 加载文件?
问题描述
我正在使用 rust 和 webassembly。我收到此错误消息operation not supported on wasm yet
。所以两件事中的任何一件都在发生,我很好奇是否有人知道答案。所以要么我的文件路径不正确,这是最没有帮助的错误消息,要么 wasm 不支持加载文件。
#[wasm_bindgen]
#[macro_use]
pub fn file() -> () {
let mut data: Vec<u8> = Vec::new();
///I would load the png with the same path in my javascript.
let opened = File::open("./png/A_SingleCell.png");
let unwraped = match opened {
Ok(a) => log(&format!("opened {}", "worked")),
Err(e) => log(&format!("{}", e)),
};
// .read_to_end(&mut data)
// .unwrap();
return ();
}
#[wasm_bindgen]
extern "C" {
#[wasm_bindgen(js_namespace = console)]
fn log(msg: &str);
}
并且 javascript 调用只是file()
.
我需要使用不同的目录路径来获取 png 还是真的不加载文件?
编辑 添加我的 index.js 以显示 webpack 已经加载了 png。
import { memory } from "break-game/break_game_bg";
import A from './png/A_SingleCell.png';
import { alloc, fill, decode, file } from "break-game";
file();
解决方案
从文件系统加载文件不适用于 Rust 标准库和wasm32-unknown-unknown
目标。因此,此错误是使用File::open
.
Rust 标准库目前为所有目标提供统一的 API 表面区域,无论目标是否实际支持该功能。事实证明,几乎所有平台基本上都实现了标准库的所有稳定表面区域,但wasm32-unknown-unknown
具体目标有点奇怪。在这个 wasm 目标上,标准库显然无法在std::net
or之类的模块中实现函数std::fs
,因此函数无条件返回错误。您在这里看到的是无条件地在目标File::open
上返回错误。wasm32-unknown-unknown
具体说一下wasm32-unknown-unknown
目标,这个目标用来表示“Rust 和 wasm 兼容的基础层”。在这个目标上,标准库只能假设 WebAssembly 指令集,没有别的。因为 WebAssembly 不提供执行 I/O 或加载文件的方法,这意味着这些存根被留在标准库中返回错误。
请注意,我们在wasm32-unknown-unknown
目标上提供标准库的另一种方法是根本不提供这些函数,当尝试使用它们时会导致编译时错误。我们选择不走这条路,无论好坏,以在 Rust 中保持跨目标的一致性。希望像提议的可移植性 lint这样的东西可以改变这个故事的演算,但 Rust 还没有完全实现!
不过,与此同时,您可能仍想完成此任务!该wasm-bindgen
项目有一些关于wasm32-unknown-unknown
目标的指南,可以帮助您在这里取得一些进展:
值得注意的是,Web 平台目前不提供从文件系统加载文件的能力,因此即使使用 JS,也没有很好的方法File::open
在 Rust 中实现目标的 API 。wasm32-unknown-unknown
但是,如果您使用的是 Node.js,我建议您阅读有关JS 互操作的信息以及查看导入 Node.js 函数以实现此功能的wasm-bindgen
指南。
推荐阅读
- python - TypeError:“NoneType”和“int”实例之间不支持“>”(Python)
- android - 底部导航图标未相对于加载的片段突出显示
- angular - 输入字段未以 Angular 11 反应形式动态更新
- java - 弹簧清除序列发生器
- amazon-s3 - s3.createPresignedPost 不适用于 ec2 角色 - 您提供的 AWS 访问密钥 ID 在我们的记录中不存在
- swiftui - 弹出窗口没有正确关闭
- python - 按条件修改数据框中的列
- reactjs - 在material-ui中单击按钮后测试菜单消失(应用程序有效,测试无效)
- visual-studio-app-center - AppCenter 跟踪来自 Web 应用程序的错误和事件
- powershell - 通过在预设输出和可变输出之间等分空格来格式化输出