--- title: ArrayBuffer slug: Web/JavaScript/Reference/Global_Objects/ArrayBuffer translation_of: Web/JavaScript/Reference/Global_Objects/ArrayBuffer ---
{{JSRef}}
Đối tượng ArrayBuffer được sử dụng để biểu diễn một bộ đệm dữ liệu nhị phân nguyên gốc có độ dài cố định. Ta không thể trực tiếp thay đổi nội dung của một ArrayBuffer; mà thay vào đó là tạo ra một typed array objects hoặc một đối tượng {{jsxref("DataView")}} đại diện cho bộ đệm với một định dạng cụ thể, và sử dụng nó để đọc và ghi nội dung của bộ đệm.
 
{{EmbedInteractiveExample("pages/js/arraybuffer-constructor.html")}}

Cú pháp

new ArrayBuffer(length)

Tham số

length
Kích thước tính theo bytes của bộ đệm mảng cần tạo

Giá trị trả về

Là một ArrayBuffer mới có kích thước được chỉ định. Nội dung khởi tạo là 0.

Ngoại lệ

Lỗi {{jsxref("RangeError")}} sẽ được đưa ra nếu length lớn hơn  {{jsxref("Number.MAX_SAFE_INTEGER")}} (>= 2 ** 53) hoặc mang giá trị âm.

Mô tả

Hàm dựng ArrayBuffer tạo ra một  ArrayBuffer  dựa trên chiều dài đã cho tính theo byte

Lấy một mảng đệm từ dữ liệu hiện có

Thuộc tính

ArrayBuffer.length
Thuộc tính chiều dài của hàm dựng của ArrayBuffer có giá trị là 1.
{{jsxref("ArrayBuffer.@@species", "get ArrayBuffer[@@species]")}}
Hàm dựng để tạo ra các đối tượng kế thừa
{{jsxref("ArrayBuffer.prototype")}}
Cho phép bổ sung các thuộc tính cho tất cả các đối tượng ArrayBuffer .

Phương thức

{{jsxref("ArrayBuffer.isView", "ArrayBuffer.isView(arg)")}}
Trả về true nếu tham số arg là một trong các views của ArrayBuffer, ví dụ như typed array objects hoặc {{jsxref("DataView")}}. Trả về false trong trường hợp ngược lại.
{{jsxref("ArrayBuffer.transfer", "ArrayBuffer.transfer(oldBuffer [, newByteLength])")}} {{experimental_inline}}
Trả về một ArrayBuffer nội dung lấy từ dữ liệu của oldBuffer và sau đó được cắt bớt hoặc không mở rộng thông qua newByteLength.

Thực thể

Tất cả các thực thể của  ArrayBuffer đều kế thừa từ {{jsxref("ArrayBuffer.prototype")}}.

Thuộc tính

{{page('en-US/Web/JavaScript/Reference/Global_Objects/ArrayBuffer/prototype','Properties')}}

Phương thức

{{page('en-US/Web/JavaScript/Reference/Global_Objects/ArrayBuffer/prototype','Methods')}}

{{jsxref("ArrayBuffer.slice()")}} {{non-standard_inline}}
Cùng chức năng như {{jsxref("ArrayBuffer.prototype.slice()")}}.

Ví dụ

Ví dụu sau tạo ra một vùng đệm 8 byte với view của {{jsxref("Global_Objects/Int32Array", "Int32Array")}} ?trỏ đến bộ đệm

var buffer = new ArrayBuffer(8);
var view   = new Int32Array(buffer);

Đặc tả

Đặc tả Trạng thái Ghi chú
{{SpecName('Typed Array')}} {{Spec2('Typed Array')}} ?Thay thế bởi ECMAScript 6.
{{SpecName('ES6', '#sec-arraybuffer-constructor', 'ArrayBuffer')}} {{Spec2('ES6')}} Initial definition in an ECMA standard. Specified that new is required.
{{SpecName('ESDraft', '#sec-arraybuffer-constructor', 'ArrayBuffer')}} {{Spec2('ESDraft')}}  

Trình duyệt tương thích

{{Compat("javascript.builtins.ArrayBuffer")}}

Ghi chú thêm về tính tương thích

Với ECMAScript 2015, hàm dựng ArrayBuffer cần được khởi tạo với {{jsxref("Operators/new", "new")}}. Việc gọi một hàm dựng ArrayBuffer nhưng một hàm thông thường không có toán tử new sẽ gây ra lỗi {{jsxref("TypeError")}}.

var dv = ArrayBuffer(10);
// TypeError: calling a builtin ArrayBuffer constructor
// without new is forbidden
var dv = new ArrayBuffer(10);

Tham khảo thêm