此页面由社区从英文翻译而来。了解更多并加入 MDN Web Docs 社区。
Float64Array
Baseline Widely available
This feature is well established and works across many devices and browser versions. It’s been available across browsers since 2015年7月.
Float64Array 类型数组代表的是平台字节顺序为 64 位的浮点数型数组 (对应于 C 浮点数据类型) 。如果需要控制字节顺序,使用DataView 替代。其内容初始化为0。一旦建立起来,你可以使用这个对象的方法对其元素进行操作,或者使用标准数组索引语法 (使用方括号)。
In this article
语法
new Float64Array(length);new Float64Array(typedArray);new Float64Array(object);new Float64Array(buffer [, byteOffset [, length]]);
更多的语法信息和参数,参见TypedArray.
静态属性
Float64Array.BYTES_PER_ELEMENT返回元素字节数。在
Float64Array的情况下返回 8。- Float64Array.length
长度属性的值为 3。关于其实际长度 (元素数量) 参见
Float64Array.prototype.length。Float64Array.prototypeTypedArray对象的原型。
静态方法
Float64Array.from()从一个类数组对象或可遍历对象创建一个新的 Float64Array。参见
Array.from()。Float64Array.of()用可变数量的参数创建一个新的 Float64Array。参见
Array.of()。
实例属性
还从其父接口TypedArray 继承实例属性。
Float64Array.prototype.constructor返回创建这个实例原型的函数。这是
Float64Array默认的构造函数。Float64Array.prototype.buffer只读返回这个
Float64Array 引用的ArrayBuffer。构造时已固定,所以是只读的。Float64Array.prototype.byteLength只读返回从
Float64Array 的ArrayBuffer开头开始的长度 (以字节为单位) 。构造时已固定,所以是只读的。Float64Array.prototype.byteOffset只读返回从
Float64Array 的ArrayBuffer开头开始的偏移量(以字节为单位) 。构造时已固定,所以是只读的。Float64Array.prototype.length只读返回
Float64Array中的元素个数。构造时已固定,所以是只读的。
实例方法
从其父接口TypedArray 继承实例方法。
示例
// From a lengthvar float64 = new Float64Array(2);float64[0] = 42;console.log(float64[0]); // 42console.log(float64.length); // 2console.log(float64.BYTES_PER_ELEMENT); // 8// From an arrayvar arr = new Float64Array([21, 31]);console.log(arr[1]); // 31// From another TypedArrayvar x = new Float64Array([21, 31]);var y = new Float64Array(x);console.log(y[0]); // 21// From an ArrayBuffervar buffer = new ArrayBuffer(32);var z = new Float64Array(buffer, 0, 4);规范
| Specification |
|---|
| ECMAScript® 2026 Language Specification> # sec-typedarray-objects> |
浏览器兼容性
一致性提示
从 ECMAScript 2015 (ES6) 开始,Float32Array 构造函数需要用一个new 操作符来构造。现在直接把Float32Array 构造函数当函数调用而不使用 new,会抛出一个TypeError。
var dv = Float64Array([1, 2, 3]);// TypeError: calling a builtin Float64Array constructor// 不允许不使用 newvar dv = new Float64Array([1, 2, 3]);