JavaScript DataView getFloat64() 方法



JavaScript DataView 的 getFloat64() 方法用於從該 DataView 中指定位元組偏移量開始檢索一個 8 位元組的浮點數。可以在指定範圍內任何位元組偏移量處檢索多個位元組的值。

浮點數是一個帶小數點的正數或負數整數。例如,5.5、0.25、-103.342 等。

如果 byteOffset 引數超出資料檢視的範圍,則會丟擲 'RangeError' 異常。

語法

以下是 JavaScript DataView getFloat64() 方法的語法:

getFloat64(byteOffset, littleEndian)

引數

此方法接受兩個名為“byteOffset”和“littleEndian”的引數,如下所述:

  • byteOffset - 從 DataView 中讀取資料的起始位置。
  • littleEndian - 指示資料是以小端還是大端格式儲存。

返回值

此方法返回一個數字值。

示例 1

以下程式演示了 JavaScript DataView getFloat64() 方法的使用。

<html>
<body>
<script>
   const buffer = new ArrayBuffer(16);
   const data_view = new DataView(buffer);
   const byteOffset = 0;
   const value = 433.45;
   document.write("The byte offset: ", byteOffset);
   document.write("<br>Value: ", value);
   //set the value
   data_view.setFloat64(byteOffset, value);
   //using getFloat64() method
   document.write("<br>The getFloat64() method: ", data_view.getFloat64(byteOffset, value));
</script>
</body>
</html>

輸出

上述程式返回儲存的值為:

The byte offset: 0
Value: 433.45
The getFloat64() method: 4.667261456827042e-62

示例 2

以下是 JavaScript DataView getFloat64() 方法的另一個示例。我們使用此方法從該 DataView 中指定位元組偏移量 1 開始檢索一個 64 位浮點數。

<html>
<body>
<script>
   const buffer = new ArrayBuffer(16);
   const data_view = new DataView(buffer);
   const byteOffset = 1;
   const value = Math.PI;
   document.write("The byte offset: ", byteOffset);
   document.write("<br>Value: ", value);
   //set the value
   data_view.setFloat64(byteOffset, value);
   //using getFloat64() method
   data_view.getFloat64(byteOffset);
   document.write("<br>The store value: ", data_view.getFloat64(byteOffset, value));
</script>
</body>
</html>

輸出

執行上述程式後,它將把指定的浮點數儲存在資料檢視中。

The byte offset: 1
Value: 3.141592653589793
The store value: 3.207375630676366e-192

示例 3

如果 byteOffset 引數的值超出此資料檢視的範圍,則會丟擲 'RangeError' 異常。

<html>
<body>
<script>
   const buffer = new ArrayBuffer(16);
   const data_view = new DataView(buffer);
   const byteOffset = -1;
   const value = 16.34;
   document.write("The byte offset: ", byteOffset);
   document.write("<br>The value: ", value);
   try {
      data_view.setFloat64(byteOffset, value);
      //using getFloat64() method
      document.write(data_view.getFloat64(byteOffset));
   } catch (error) {
      document.write("<br>Error: ", error);
   }
</script>
</body>
</html>

輸出

執行上述程式後,將丟擲“RangeError”異常,如下所示:

The byte offset: -1
The value: 16.34
Error: RangeError: Offset is outside the bounds of the DataView
廣告