Uint8Array 数组类型表示一个8位无符号整型数组,创建时内容被初始化为0。创建完后,可以以对象的方式或使用数组下标索引的方式引用数组中的元素。
语法格式
new Uint8Array(); // ES2017 最新语法 new Uint8Array(length); // 创建初始化为0的,包含length个元素的无符号整型数组 new Uint8Array(typedArray); new Uint8Array(object); new Uint8Array(buffer [, byteOffset [, length]]);
构造语法和参数的更多信息请参见 TypedArray.
属性
-
Uint8Array.BYTES_PER_ELEMENT - 返回数组中元素的字节数,Uint8Array中返回1字节。
- Uint8Array.length
-
静态属性length一直为0。想获知其真实长度(元素个数),请参阅
Uint8Array.prototype.length. -
Uint8Array.name - 返回构造名的字符串,对Uint8Array类型而言返回 “Uint8Array”
-
Uint8Array.prototype - TypedArray 对象的原型.
方法
-
Uint8Array.from() -
从一个数组或可迭代的对象创建一个新的
Uint8Array数组,可参见Array.from(). -
Uint8Array.of() -
通过一个可变数目的参数创建一个新的
Uint8Array数组,可参见Array.of().
Uint8Array 原型声明
所有的Uint8Array对象继承自 %TypedArray%.prototype.
属性
-
Uint8Array.prototype.constructor -
返回创建实例属性的函数,默认为
Uint8Array构造器。 -
Uint8Array.prototype.buffer只读 -
返回由
Uint8Array引用的ArrayBuffer,在构造时期固定,所以是 只读的。 -
Uint8Array.prototype.byteLength只读 -
返回
Uint8Array长度(字节数)。在构造时期固定,所以是 只读的。 -
Uint8Array.prototype.byteOffset只读 -
返回
Uint8Array距离其ArrayBuffer起始位置的偏移(字节数)。在构造时期固定,所以是 只读的。 -
Uint8Array.prototype.length只读 -
返回保存在
Uint8Array中的元素数量。 在构造时期固定,所以是 只读的。
方法
-
Uint8Array.prototype.copyWithin() -
复制数组中的元素序列,请参见
Array.prototype.copyWithin()。 -
Uint8Array.prototype.entries() -
返回新的
Array Iterator对象,含有数组中每个下标处的键值对。请参见Array.prototype.entries(). -
Uint8Array.prototype.every() -
测试数组中所有元素是否都能通过由函数提供的测试。请参见
Array.prototype.every()。 -
Uint8Array.prototype.fill() -
使用静态值填充从起始下标到终止下标的数组元素。请参见
Array.prototype.fill()。 -
Uint8Array.prototype.filter() -
创建新的数组,含有数组中给定过滤器返回 true 的所有元素。请参见
Array.prototype.filter(). -
Uint8Array.prototype.find() -
如果数组中的元素满足提供的测试函数,返回找到的值,如果没有找到则返回
undefined。请参见Array.prototype.find()。 -
Uint8Array.prototype.findIndex() -
如果数组中的元素满足提供的测试函数,返回找到的下标,如果没有找到则返回 -1。请参见
Array.prototype.findIndex(). -
Uint8Array.prototype.forEach() -
对数组的每个元素调用字符串
Array.prototype.forEach()。 -
Uint8Array.prototype.includes() -
判断类型化数组是否包含特定值,如果包含返回
true,否则返回false。另见Array.prototype.includes()。 -
Uint8Array.prototype.indexOf() -
返回数组中等于特定值的第一个元素(下标最小),如果没有找到则返回 -1,请参见
Array.prototype.indexOf(). -
Uint8Array.prototype.join() -
将数组中所有元素连接为字符串。请参见
Array.prototype.join()。 -
Uint8Array.prototype.keys() -
返回新的
Array Iterator,含有数组中每个下标的键,请参见Array.prototype.keys()。 -
Uint8Array.prototype.lastIndexOf() -
返回数组中等于特定值的最后一个元素(下标最大),如果没有找到则返回 -1,请参见
Array.prototype.lastIndexOf()。 -
Uint8Array.prototype.map() -
使用在该数组的每个元素上调用函数的结果创建新数组,请参见
Array.prototype.map()。 -
Uint8Array.prototype.move()未实现 -
Uint8Array.prototype.copyWithin()的之前的非标准版本。 -
Uint8Array.prototype.reduce() -
对累加器和数组的每个值应用函数(从左到右),使其归约为单一的值, 另见
Array.prototype.reduce()。 -
Uint8Array.prototype.reduceRight() -
对累加器和数组的每个值应用函数(从右到左),使其归约为单一的值, 另见
Array.prototype.reduceRight()。 -
Uint8Array.prototype.reverse() -
翻转数组中的元素顺序 — 第一个变为最后,最后变为第一个。另见
Array.prototype.reverse()。 -
Uint8Array.prototype.set() - 在类型化数组中储存多个值,从特定数组中读取输入。
-
Uint8Array.prototype.slice() -
提取数组的某个部分并返回新的数组,请参见
Array.prototype.slice()。 -
Uint8Array.prototype.some() -
如果数组中至少一个元素满足给定的测试函数,则返回
true。请参见Array.prototype.some()。 -
Uint8Array.prototype.sort() -
原地排序数组中的元素,并返回该数组,请参见
Array.prototype.sort()。 -
Uint8Array.prototype.subarray() -
从给定的元素起始和终止下标返回新的 Uint8Array。 -
Uint8Array.prototype.values() -
返回新的
Array Iterator对象,含有数组每个下标处的值,请参见Array.prototype.values()。 -
Uint8Array.prototype.toLocaleString() -
返回表示数组及其元素的本地化字符串,请参见
Array.prototype.toLocaleString()。 -
Uint8Array.prototype.toString() -
返回表示数组及其元素的字符串。请参见
Array.prototype.toString()。 -
Uint8Array.prototype[@@iterator]() -
返回新的 Array Iterator对象,包含数组中每个下标处的值。
例子
// 来自长度
var uint8 = new Uint8Array(2);
uint8[0] = 42;
console.log(uint8[0]); // 42
console.log(uint8.length); // 2
console.log(uint8.BYTES_PER_ELEMENT); // 1
// 来自数组
var arr = new Uint8Array([21,31]);
console.log(arr[1]); // 31
// 来自另一个 TypedArray
var x = new Uint8Array([21, 31]);
var y = new Uint8Array(x);
console.log(y[0]); // 21
// 来自 ArrayBuffer
var buffer = new ArrayBuffer(8);
var z = new Uint8Array(buffer, 1, 4);
// 来自一个迭代器
var iterable = function*(){ yield* [1,2,3]; }();
var uint8 = new Uint8Array(iterable);
// Uint8Array[1, 2, 3]
规范
| Specification | Status | Comment |
|---|---|---|
| 类型化数组规范 | Obsolete | 由 ECMAScript 6 取代。 |
| ECMAScript 2015 (6th Edition, ECMA-262) TypedArray constructors |
Standard | ECMA 标准中的初始定义。 |
浏览器兼容性
The compatibility table on this page is generated from structured data. If you'd like to contribute to the data, please check out
https://github.com/mdn/browser-compat-data and send us a pull request.
Update compatibility data on GitHub
| Desktop | Mobile | Server | |||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
Uint8Array |
Chrome Full support 7 | Edge Full support 12 | Firefox Full support 4 | IE Full support 10 | Opera Full support 11.6 | Safari Full support 5.1 | WebView Android Full support 4 | Chrome Android Full support 18 | Firefox Android Full support 4 | Opera Android Full support 12 | Safari iOS Full support 4.2 | Samsung Internet Android Full support Yes | nodejs Full support 0.10 |
| Constructor without arguments | Chrome Full support 7 | Edge Full support 12 | Firefox Full support 55 | IE Full support 10 | Opera Full support Yes | Safari Full support 5.1 | WebView Android Full support ≤37 | Chrome Android Full support 18 | Firefox Android Full support 55 | Opera Android Full support Yes | Safari iOS Full support 5 | Samsung Internet Android Full support 1.0 | nodejs ? |
| Iterable in constructor | Chrome Full support 39 | Edge Full support 14 | Firefox Full support 52 | IE No support No | Opera Full support 26 | Safari ? | WebView Android Full support 39 | Chrome Android Full support 39 | Firefox Android Full support 52 | Opera Android Full support 26 | Safari iOS ? | Samsung Internet Android Full support 4.0 | nodejs Full support 4.0.0 |
Uint8Array() without new throws |
Chrome Full support 7 | Edge Full support 14 | Firefox Full support 44 | IE No support No | Opera Full support Yes | Safari Full support 5.1 | WebView Android Full support ≤37 | Chrome Android Full support 18 | Firefox Android Full support 44 | Opera Android Full support Yes | Safari iOS Full support 5 | Samsung Internet Android Full support 1.0 | nodejs Full support 0.12 |
Legend
- Full support
- Full support
- No support
- No support
- Compatibility unknown
- Compatibility unknown
兼容性说明
从 ECMAScript 2015 开始,Uint8Array 构造函数需要通过 TypeError 。
var dv = Uint8Array([1, 2, 3]); // TypeError: calling a builtin Uint8Array constructor // 不使用 new 将会被禁止
var dv = new Uint8Array([1, 2, 3]);