JavaScript DataView getFloat32() 方法



JavaScript DataView 的 getFloat32() 方法用于从该数据视图的指定字节偏移量开始检索 4 字节浮点数,并将其解码为 32 位浮点数。您可以从边界内的任何偏移量获取多个字节值。

如果字节偏移量参数的值超出此数据视图的范围,则此方法会抛出 'RangeError' 异常。

语法

以下是 JavaScript DataView getFloat32() 方法的语法:

getFloat32(byteOffset, littleEndian)

参数

此方法接受两个名为“byteOffset”和“littleEndian”的参数,如下所述:

  • byteOffset - 从中读取数据的 DataView 中的位置。
  • littleEndian (可选) - 指示数据是以小端序还是大端序存储。

返回值

此方法返回一个介于 -3.4e38 到 3.4e38 之间的整数。

示例 1

以下是 JavaScript DataView getFloat32() 方法的基本示例。

<html>
<body>
<script>
   const buffer = new ArrayBuffer(16);
   const data_view = new DataView(buffer);
   const byteOffset = 0;
   const value = Math.PI;
   document.write("The byte offset: ", byteOffset);
   document.write("<br>Value: ", value);
   //storing the value
   data_view.setFloat32(byteOffset, value);
   document.write("<br>The stored value: ", data_view.getFloat32(byteOffset));
</script>
</body>
</html>

输出

以上程序返回存储的值“3.1415927410125732”。

The byte offset: 0
Value: 3.141592653589793
The stored value: 3.1415927410125732

示例 2

如果 byteOffset 参数值超出此数据视图的范围,则会抛出 'RangeError' 异常。

<html>
<body>
<script>
   const buffer = new ArrayBuffer(16);
   const data_view = new DataView(buffer);
   const byteOffset = 1;
   const value = 3.445323412;
   document.write("The byte offset: ", byteOffset);
   document.write("<br>Value: ", value);
   //storing the value
   data_view.setFloat32(byteOffset, value);
   try {
      document.write("<br>The stored value: ", data_view.getFloat32(-1));
   } catch (error) {
      document.write("<br>", error);
   }
</script>
</body>
</html>

输出

执行上述程序后,将抛出以下异常:

The byte offset: 1
Value: 3.445323412
RangeError: Offset is outside the bounds of the DataView
广告