--- title: Float64Array slug: Web/JavaScript/Reference/Global_Objects/Float64Array tags: - JavaScript - TypeArray - TypeArrays - 构造函数 translation_of: Web/JavaScript/Reference/Global_Objects/Float64Array ---
{{JSRef}}

Float64Array 类型数组代表的是平台字节顺序为64位的浮点数型数组(对应于 C 浮点数据类型) 。 如果需要控制字节顺序, 使用 {{jsxref("DataView")}} 替代。其内容初始化为0。一旦建立起来,你可以使用这个对象的方法对其元素进行操作,或者使用标准数组索引语法 (使用方括号)。

?语法 

new Float64Array(length);
new Float64Array(typedArray);
new Float64Array(object);
new Float64Array(buffer [, byteOffset [, length]]);

更多的语法信息和参数,参见 TypedArray.

属性

{{jsxref("TypedArray.BYTES_PER_ELEMENT", "Float64Array.BYTES_PER_ELEMENT")}}
返回元素字节数。  Float64Array的情况下返回8。
Float64Array.length
长度属性的值为 3。关于其实际长度(元素数量)参见 {{jsxref("TypedArray.prototype.length", "Float64Array.prototype.length")}}。
{{jsxref("TypedArray.name", "Float64Array.name")}}
返回构造函数名字的字符串值。在 Float64Array 类型的情况下为:"Float64Array"。
{{jsxref("TypedArray.prototype", "Float64Array.prototype")}}
TypedArray对象的原型。

方法

{{jsxref("TypedArray.from", "Float64Array.from()")}}
从一个类数组对象或可遍历对象创建一个新的Float64Array。参见 {{jsxref("Array.from()")}}。
{{jsxref("TypedArray.of", "Float64Array.of()")}}
用可变数量的参数创建一个新的Float64Array。 参见 {{jsxref("Array.of()")}}。

Float64Array 属性

所有的Float64Array对象都继承自 {{jsxref("TypedArray.prototype", "%TypedArray%.prototype")}}。

特性

Float64Array.prototype.constructor
返回创建这个实例原型的函数。 这是Float64Array 默认的构造函数。
{{jsxref("TypedArray.prototype.buffer", "Float64Array.prototype.buffer")}} {{readonlyInline}}
返回这个Float64Array引用的 {{jsxref("ArrayBuffer")}}。构造时已固定,所以是只读的。
{{jsxref("TypedArray.prototype.byteLength", "Float64Array.prototype.byteLength")}} {{readonlyInline}}
返回从Float64Array的{{jsxref("ArrayBuffer")}}开头开始长度 (以字节为单位) 。构造时已固定,所以是只读的。
{{jsxref("TypedArray.prototype.byteOffset", "Float64Array.prototype.byteOffset")}} {{readonlyInline}}
返回从Float64Array的{{jsxref("ArrayBuffer")}}开头开始的偏移量 (以字节为单位) 。构造时已固定,所以是只读的。
{{jsxref("TypedArray.prototype.length", "Float64Array.prototype.length")}} {{readonlyInline}}
返回Float64Array中的元素个数。构造时已固定,所以是只读的。

方法

{{jsxref("TypedArray.copyWithin", "Float64Array.prototype.copyWithin()")}}
从数组复制元素。参见{{jsxref("Array.prototype.copyWithin()")}}。
{{jsxref("TypedArray.entries", "Float64Array.prototype.entries()")}}
返回一个包含数组中每个元素键值对的数组遍历器对象。参见{{jsxref("Array.prototype.entries()")}}。
{{jsxref("TypedArray.every", "Float64Array.prototype.every()")}}
检测是否所有元素都能通过给定函数的测试。参见{{jsxref("Array.prototype.every()")}}。
{{jsxref("TypedArray.fill", "Float64Array.prototype.fill()")}}
用一个静态值填充给定的起始位置。 参见{{jsxref("Array.prototype.fill()")}}。
{{jsxref("TypedArray.filter", "Float64Array.prototype.filter()")}}
创建一个新数组,数据为原数组中所有能让给入函数返回true的元素。参见{{jsxref("Array.prototype.filter()")}}。
{{jsxref("TypedArray.find", "Float64Array.prototype.find()")}}
返回满足测试函数的值,如果没有找到,返回undefined。 参见{{jsxref("Array.prototype.find()")}}。
{{jsxref("TypedArray.findIndex", "Float64Array.prototype.findIndex()")}}
返回满足测试函数的值的位置,如果没有找到,返回-1。参见{{jsxref("Array.prototype.findIndex()")}}。
{{jsxref("TypedArray.forEach", "Float64Array.prototype.forEach()")}}
以每个元素为参数各调用一次函数。参见{{jsxref("Array.prototype.forEach()")}}。
{{jsxref("TypedArray.includes", "Float64Array.prototype.includes()")}} {{experimental_inline}}
判断是否包含某个元素,返回truefalse。参见{{jsxref("Array.prototype.includes()")}}。
{{jsxref("TypedArray.indexOf", "Float64Array.prototype.indexOf()")}}
返回数组中等于给定值的元素的第一个(最小)位置, 没有找到则返回-1。参见{{jsxref("Array.prototype.indexOf()")}}。
{{jsxref("TypedArray.join", "Float64Array.prototype.join()")}}
合并所有数组元素到一个字符串中。 参见{{jsxref("Array.prototype.join()")}}。
{{jsxref("TypedArray.keys", "Float64Array.prototype.keys()")}}
返回一个包含数组中所有索引的数组遍历器。 参见{{jsxref("Array.prototype.keys()")}}。
{{jsxref("TypedArray.lastIndexOf", "Float64Array.prototype.lastIndexOf()")}}
返回数组中等于给定值的元素的最后(最大)位置, 没有找到则返回-1。参见{{jsxref("Array.prototype.lastIndexOf()")}}。
{{jsxref("TypedArray.map", "Float64Array.prototype.map()")}}
创建一个新的数组,数据由原数组每个元素依次传入给定函数后返回的值组成。参见{{jsxref("Array.prototype.map()")}}。
{{jsxref("TypedArray.move", "Float64Array.prototype.move()")}} {{non-standard_inline}} {{unimplemented_inline}}
{{jsxref("TypedArray.copyWithin", "Float64Array.prototype.copyWithin()")}}以前的一个非标准版本。
{{jsxref("TypedArray.reduce", "Float64Array.prototype.reduce()")}}
传入一个函数作为累加器,从左到右遍历,最终得到一个值。 参见{{jsxref("Array.prototype.reduce()")}}。
{{jsxref("TypedArray.reduceRight", "Float64Array.prototype.reduceRight()")}}
传入一个函数作为累加器,从右到左遍历,最终得到一个值。参见{{jsxref("Array.prototype.reduceRight()")}}。
{{jsxref("TypedArray.reverse", "Float64Array.prototype.reverse()")}}
反转数组元素的顺序 — 第一个变为最后一个, 最后一个变为第一个。参见{{jsxref("Array.prototype.reverse()")}}。
{{jsxref("TypedArray.set", "Float64Array.prototype.set()")}}
从给定的数组存入多个数值。
{{jsxref("TypedArray.slice", "Float64Array.prototype.slice()")}}
提取数组的一部分并且返回一个新数组。参见{{jsxref("Array.prototype.slice()")}}。
{{jsxref("TypedArray.some", "Float64Array.prototype.some()")}}
如果数组中至少有一个元素满足测试函数的要求则返回true。参见{{jsxref("Array.prototype.some()")}}。
{{jsxref("TypedArray.sort", "Float64Array.prototype.sort()")}}
对数组元素进行排序并返回数组。参见{{jsxref("Array.prototype.sort()")}}。
{{jsxref("TypedArray.subarray", "Float64Array.prototype.subarray()")}}
从给定的起始位置返回一个新的Float64Array 。
{{jsxref("TypedArray.values", "Float64Array.prototype.values()")}}
返回一个包含所有数组元素的数组遍历器对象。 参见{{jsxref("Array.prototype.values()")}}。
{{jsxref("TypedArray.toLocaleString", "Float64Array.prototype.toLocaleString()")}}
返回一个代表数组和其元素的本地化格式字符串。参见{{jsxref("Array.prototype.toLocaleString()")}}。
{{jsxref("TypedArray.toString", "Float64Array.prototype.toString()")}}
返回一个代表数组和它的元素的字符串。参见{{jsxref("Array.prototype.toString()")}}。
{{jsxref("TypedArray.@@iterator", "Float64Array.prototype[@@iterator]()")}}
返回一个新的包含数组元素的数组迭代器对象。

例子

// From a length
var float64 = new Float64Array(2);
float64[0] = 42;
console.log(float64[0]); // 42
console.log(float64.length); // 2
console.log(float64.BYTES_PER_ELEMENT); // 8

// From an array
var arr = new Float64Array([21,31]);
console.log(arr[1]); // 31

// From another TypedArray
var x = new Float64Array([21, 31]);
var y = new Float64Array(x);
console.log(y[0]); // 21

// From an ArrayBuffer
var buffer = new ArrayBuffer(32);
var z = new Float64Array(buffer, 0, 4);

规范

?规范 ?状态 ?注释
{{SpecName('Typed Array')}} {{Spec2('Typed Array')}} 被ECMAScript 6取代。
{{SpecName('ES6', '#table-49', 'TypedArray constructors')}} {{Spec2('ES6')}} 在ECMA中初始定义,另外规定需要使用new。
{{SpecName('ESDraft', '#table-49', 'TypedArray constructors')}} {{Spec2('ESDraft')}}  

浏览器兼容

{{CompatibilityTable}}

特性 Chrome Firefox (Gecko) Internet Explorer Opera Safari
基础支持 7.0 {{CompatGeckoDesktop(2)}} 10 11.6 5.1
需要用new {{CompatUnknown}} {{CompatGeckoDesktop(44)}} {{CompatUnknown}} {{CompatUnknown}} {{CompatUnknown}}
特性 Android Chrome for Android Firefox Mobile (Gecko) IE Mobile Opera Mobile Safari Mobile
基础支持 4.0 {{CompatVersionUnknown}} {{ CompatGeckoMobile(2) }} 10 11.6 4.2
需要用new {{CompatUnknown}} {{CompatUnknown}} {{ CompatGeckoMobile(44) }} {{CompatUnknown}} {{CompatUnknown}} {{CompatUnknown}}

一致性提示

从ECMAScript 2015 (ES6)开始, Float32Array构造函数需要用一个{{jsxref("Operators/new", "new")}}操作符来构造。现在直接把Float32Array构造函数当函数调用而不使用new,会抛出一个{{jsxref("TypeError")}}。

var dv = Float64Array([1, 2, 3]);
// TypeError: calling a builtin Float64Array constructor
// 不允许不使用new
var dv = new Float64Array([1, 2, 3]);

参见