From c01e8779a5fed876331e3933e8e19e1daecab11c Mon Sep 17 00:00:00 2001 From: Masahiro FUJIMOTO Date: Tue, 7 Sep 2021 00:43:07 +0900 Subject: Global_Objects/WebAssembly/Table 以下の文書を更新 (#2265) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit - Markdownに変換 - 2021/08/28 時点の英語版に同期 --- .../webassembly/table/get/index.html | 77 ---------------------- .../global_objects/webassembly/table/get/index.md | 68 +++++++++++++++++++ 2 files changed, 68 insertions(+), 77 deletions(-) delete mode 100644 files/ja/web/javascript/reference/global_objects/webassembly/table/get/index.html create mode 100644 files/ja/web/javascript/reference/global_objects/webassembly/table/get/index.md (limited to 'files/ja/web/javascript/reference/global_objects/webassembly/table/get') diff --git a/files/ja/web/javascript/reference/global_objects/webassembly/table/get/index.html b/files/ja/web/javascript/reference/global_objects/webassembly/table/get/index.html deleted file mode 100644 index ebcbd78d9f..0000000000 --- a/files/ja/web/javascript/reference/global_objects/webassembly/table/get/index.html +++ /dev/null @@ -1,77 +0,0 @@ ---- -title: WebAssembly.Table.prototype.get() -slug: Web/JavaScript/Reference/Global_Objects/WebAssembly/Table/get -tags: - - API - - JavaScript - - Method - - Reference - - WebAssembly - - get - - table - - メソッド -translation_of: Web/JavaScript/Reference/Global_Objects/WebAssembly/Table/get ---- -
{{JSRef}}
- -

get() は {{jsxref("WebAssembly.Table")}} オブジェクトのプロトタイプメソッドで、指定されたインデックスに格納された関数参照を取得します。

- -

構文

- -
table.get(index);
-
- -

引数

- -
-
index
-
取得する関数参照のインデックス。
-
- -

返値

- -

関数参照を返します。これは エクスポートされた WebAssembly 関数 、wasm 関数を内在する JavaScript ラッパーです。

- -

例外

- -

もし index が {{jsxref("WebAssembly/Table/length","Table.prototype.length")}} 以上だった場合、{{jsxref("RangeError")}} をスローします。

- -

- -

次の例では (Github の table.html動作例 も確認してください)、fetchAndInstantiate() ユーティリティ関数を使用して table.wasm バイトコードをロード、コンパイルして、インスタンス化しています。その後、エクスポートされたテーブルに格納された参照を取得します。

- -
WebAssembly.instantiateStreaming(fetch('table.wasm'))
-.then(function(obj) {
-  var tbl = obj.instance.exports.tbl;
-  console.log(tbl.get(0)());  // 13
-  console.log(tbl.get(1)());  // 42
-});
- -

参照内に格納されている値を実際に取得するためには、アクセサの最後に2つ目の関数呼び出し演算子を含める必要があります(get(0) ではなく get(0)()) 。これは単純な値ではなく、関数です。

- -

仕様書

- - - - - - - - - - - - -
仕様書
{{SpecName('WebAssembly JS', '#dom-table-get', 'get()')}}
- -

ブラウザーの互換性

- -

{{Compat("javascript.builtins.WebAssembly.Table.get")}}

- -

関連情報

- - diff --git a/files/ja/web/javascript/reference/global_objects/webassembly/table/get/index.md b/files/ja/web/javascript/reference/global_objects/webassembly/table/get/index.md new file mode 100644 index 0000000000..826de450ca --- /dev/null +++ b/files/ja/web/javascript/reference/global_objects/webassembly/table/get/index.md @@ -0,0 +1,68 @@ +--- +title: WebAssembly.Table.prototype.get() +slug: Web/JavaScript/Reference/Global_Objects/WebAssembly/Table/get +tags: + - API + - JavaScript + - メソッド + - Reference + - WebAssembly + - get + - table +browser-compat: javascript.builtins.WebAssembly.Table.get +translation_of: Web/JavaScript/Reference/Global_Objects/WebAssembly/Table/get +--- +{{JSRef}} + +**`get()`** は {{jsxref("WebAssembly.Table")}} オブジェクトのプロトタイプメソッドで、指定された位置に格納されている関数参照を取得します。 + +## 構文 + +```js +get(index) +``` + +### 引数 + +- _index_ + - : 取得する関数参照の位置です。 + +### 返値 + +関数参照を返します。これは[エクスポートされた WebAssembly 関数](/ja/docs/WebAssembly/Exported_functions)、wasm 関数を内在する JavaScript ラッパーです。

+ +### 例外 + +_index_ が {{jsxref("WebAssembly/Table/length","Table.prototype.length")}} 以上であった場合、{{jsxref("RangeError")}} が発生します。 + +## 例 + +### get の使用 + +次の例では (Github の [table.html](https://github.com/mdn/webassembly-examples/blob/master/js-api-examples/table.html) と[動作例](https://mdn.github.io/webassembly-examples/js-api-examples/table.html)も確認してください)、 table.wasm バイトコードを +{{jsxref("WebAssembly.instantiateStreaming()")}} メソッドを使用して読み取り、コンパイルしてインスタンス化しています。その後、エクスポートされたテーブルに格納された参照を取得します。 + +```js +WebAssembly.instantiateStreaming(fetch('table.wasm')) +.then(function(obj) { +  var tbl = obj.instance.exports.tbl; +  console.log(tbl.get(0)());  // 13 +  console.log(tbl.get(1)());  // 42 +}); +``` + +参照に格納されている値を実際に取得するためには、アクセサーの最後に 2 つ目の関数呼び出し演算子を含める必要があります (`get(0)` ではなく `get(0)()`)。これは単純な値ではなく、関数です。 + +## 仕様書 + +{{Specifications}} + +## ブラウザーの互換性 + +{{Compat}} + +## 関連情報 + +- [WebAssembly](/ja/docs/WebAssembly) 概要ページ +- [WebAssembly の概念](/ja/docs/WebAssembly/Concepts) +- [WebAssembly JavaScript API の使用](/ja/docs/WebAssembly/Using_the_JavaScript_API) -- cgit v1.2.3-54-g00ecf