JS如何調(diào)用WebAssembly編譯出來(lái)的.wasm文件
WebAssembly也叫瀏覽器字節(jié)碼技術(shù) 這里就不過(guò)多的解釋了網(wǎng)上很多介紹
主要是讓大家知道在js里面如何調(diào)用執(zhí)行它,我之前看WebAssemblyAPI時(shí)候反正是看得一臉懵逼
也是為了大家能更快的入手這個(gè)比較新的技術(shù)吧
這邊寫(xiě)的一個(gè)dom是官方推薦的c/c++編譯的
c代碼
int add (int x, int y) {
return x + y;
}
int square (int x) {
return x * x;
}
屬性c但是對(duì)字節(jié)碼不熟悉的朋友可能會(huì)不理解,為什么沒(méi)有main函數(shù)
這里主要是把這個(gè)c代碼當(dāng)成一個(gè)模塊調(diào)用不需要它自己執(zhí)行所以沒(méi)有,官方也有有main函數(shù)的能直接生成js和html但是太過(guò)雍于,
這種方式比較推薦,也是讓js能直接調(diào)用比較方便
之后使用 emscripten進(jìn)行編譯 emcc math.c -Os -s WASM=1 -s SIDE_MODULE=1 -o math.wasm
然后就有math.wasm文件了,如果沒(méi)裝emscripten的話我博客里面有一篇是關(guān)于安裝的
有了math.wasm文件后就該用js調(diào)用它了
新建math.html加入調(diào)用的方法如下:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>Document</title>
</head>
<body>
<h1>
</h1>
<script>
/**
* @param {String} path wasm 文件路徑
* @param {Object} imports 傳遞到 wasm 代碼中的變量
*/
function loadWebAssembly (path, imports = {}) {
return fetch(path) // 加載文件
.then(response => response.arrayBuffer()) // 轉(zhuǎn)成 ArrayBuffer
.then(buffer => WebAssembly.compile(buffer))
.then(module => {
imports.env = imports.env || {}
// 開(kāi)辟內(nèi)存空間
imports.env.memoryBase = imports.env.memoryBase || 0
if (!imports.env.memory) {
imports.env.memory = new WebAssembly.Memory({ initial: 256 })
}
// 創(chuàng)建變量映射表
imports.env.tableBase = imports.env.tableBase || 0
if (!imports.env.table) {
// 在 MVP 版本中 element 只能是 "anyfunc"
imports.env.table = new WebAssembly.Table({ initial: 0, element: 'anyfunc' })
}
// 創(chuàng)建 WebAssembly 實(shí)例
return new WebAssembly.Instance(module, imports)
})
}
//調(diào)用
loadWebAssembly('./math.wasm')
.then(instance => {
const add = instance.exports._add//取出c里面的方法
const square = instance.exports._square//取出c里面的方法
console.log('10 + 20 =', add(10, 20))
console.log('3*3 =', square(3))
console.log('(2 + 5)*2 =', square(add(2 + 5)))
})
</script>
</body>
</html>
我這里的路徑math.html和math.wasm是同級(jí)的
現(xiàn)在就可以打開(kāi)瀏覽器查看了 但是fetch方法在本地是不能使用的它是網(wǎng)絡(luò)請(qǐng)求 所有這里需要來(lái)個(gè)web服務(wù)器
打開(kāi)終端之間鍵入 npm install -g serve
下載web服務(wù)器
然后serve . 啟動(dòng)
有點(diǎn)的 .
啟動(dòng)完成效果:

然后通過(guò)web服務(wù)器訪問(wèn)就能看到調(diào)用c方法后的計(jì)算結(jié)果:

到此這篇關(guān)于關(guān)于WebAssembly編譯出來(lái)的.wasm文件js如何調(diào)用的文章就介紹到這了,更多相關(guān)js調(diào)用.wasm文件內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
用javascript實(shí)現(xiàn)的仿Flash廣告圖片輪換效果
用javascript實(shí)現(xiàn)的仿Flash廣告圖片輪換效果...2007-04-04
替代window.event.srcElement效果的可兼容性的函數(shù)
getEvent()方法可模擬window.event效果2009-12-12
微信小程序獲取復(fù)選框全選反選選中的值(實(shí)例代碼)
這篇文章主要介紹了微信小程序獲取復(fù)選框全選反選選中的值,本文通過(guò)實(shí)例代碼給大家簡(jiǎn)單介紹,需要的朋友可以參考下2019-12-12
three.js中文文檔學(xué)習(xí)之通過(guò)模塊導(dǎo)入
這篇文章主要給大家介紹了關(guān)于three.js中文文檔學(xué)習(xí)之通過(guò)模塊導(dǎo)入的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或使用three.js具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。2017-11-11
微信小程序?qū)崿F(xiàn)圖片翻轉(zhuǎn)效果的實(shí)例代碼
這篇文章主要介紹了微信小程序?qū)崿F(xiàn)圖片翻轉(zhuǎn)效果的實(shí)例代碼,代碼簡(jiǎn)單易懂,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-09-09
ES6 Symbol在對(duì)象中的作用實(shí)例分析
這篇文章主要介紹了ES6 Symbol在對(duì)象中的作用,結(jié)合實(shí)例形式分析了ES6 Symbol在對(duì)象中聲明、使用方法與相關(guān)注意事項(xiàng),需要的朋友可以參考下2020-06-06
JavaScript移除數(shù)組元素減少長(zhǎng)度的方法
數(shù)組想必大家對(duì)它并不陌生吧,有些新手朋友們都不知道如何移除數(shù)組元素,下面為大家介紹個(gè)示例,喜歡的朋友可以了解下2013-09-09

