JS如何調(diào)用WebAssembly編譯出來的.wasm文件
WebAssembly也叫瀏覽器字節(jié)碼技術(shù) 這里就不過多的解釋了網(wǎng)上很多介紹
主要是讓大家知道在js里面如何調(diào)用執(zhí)行它,我之前看WebAssemblyAPI時候反正是看得一臉懵逼
也是為了大家能更快的入手這個比較新的技術(shù)吧
這邊寫的一個dom是官方推薦的c/c++編譯的
c代碼
int add (int x, int y) { return x + y; } int square (int x) { return x * x; }
屬性c但是對字節(jié)碼不熟悉的朋友可能會不理解,為什么沒有main函數(shù)
這里主要是把這個c代碼當(dāng)成一個模塊調(diào)用不需要它自己執(zhí)行所以沒有,官方也有有main函數(shù)的能直接生成js和html但是太過雍于,
這種方式比較推薦,也是讓js能直接調(diào)用比較方便
之后使用 emscripten進(jìn)行編譯 emcc math.c -Os -s WASM=1 -s SIDE_MODULE=1 -o math.wasm
然后就有math.wasm文件了,如果沒裝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 || {} // 開辟內(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是同級的
現(xiàn)在就可以打開瀏覽器查看了 但是fetch方法在本地是不能使用的它是網(wǎng)絡(luò)請求 所有這里需要來個web服務(wù)器
打開終端之間鍵入 npm install -g serve
下載web服務(wù)器
然后serve . 啟動
有點(diǎn)的 .
啟動完成效果:
然后通過web服務(wù)器訪問就能看到調(diào)用c方法后的計(jì)算結(jié)果:
到此這篇關(guān)于關(guān)于WebAssembly編譯出來的.wasm文件js如何調(diào)用的文章就介紹到這了,更多相關(guān)js調(diào)用.wasm文件內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
純JS實(shí)現(xiàn)根據(jù)CSS的class選擇DOM
這篇文章主要介紹了純JS實(shí)現(xiàn)根據(jù)CSS的class選擇DOM,需要的朋友可以參考下2014-03-03TypeScript對于Duck類型和模塊命名空間應(yīng)用
這篇文章主要介紹了TypeScript對于Duck類型和模塊命名空間應(yīng)用,Duck類型是一種動態(tài)類型和多態(tài)形式,在duck類型中,重點(diǎn)是對象的行為可以做什么,而不是對象所屬的類型2022-08-08javascript實(shí)現(xiàn)時間日期的格式化的方法匯總
這篇文章主要介紹了javascript實(shí)現(xiàn)時間日期的格式化的方法匯總,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-08-08使用BootStrap實(shí)現(xiàn)用戶登錄界面UI
本文給大家介紹使用BootStrap實(shí)現(xiàn)用戶登錄界面UI,布局風(fēng)格采用左右各一半的風(fēng)格設(shè)計(jì),非常不錯,具有參考借鑒價值,感興趣的朋友一起學(xué)習(xí)吧2016-08-08layui+SSM的數(shù)據(jù)表的增刪改實(shí)例(利用彈框添加、修改)
今天小編就為大家分享一篇layui+SSM的數(shù)據(jù)表的增刪改實(shí)例(利用彈框添加、修改),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-09-09bootstrap-treeview實(shí)現(xiàn)多級樹形菜單 后臺JSON格式如何組織?
這篇文章主要介紹了bootstrap-treeview實(shí)現(xiàn)多級樹形菜單,后臺JSON格式如何組織,具有一定的參考價值,感興趣的小伙伴們可以參考一下2019-07-07javascript 動態(tài)改變層的Z-INDEX的代碼style.zIndex
javascript 動態(tài)改變層的Z-INDEX的代碼style.zIndex...2007-08-08