Polyfill 基础知识:如何为 Uint8Array.fill 实现 polyfill
Polyfill basics: How to implement a polyfill for Uint8Array.fill
Polyfill 新手在这里。我对这个简单的案例感到非常困惑,其中我想初始化一个类型化数组:
var x = new Uint8Array(3).fill(42);
console.log(x);
这在Chrome和Firefox中工作正常:控制台显示[42, 42, 42]
。不支持fill
方法的 Safari 会抛出此错误:"TypeError: new Uint8Array(3).fill is not a function."
。这是完全有道理的。所以我想我需要实现一个填充物,对吧?右!MDN 提供了这个,但是当我添加这段代码时,没有任何变化:Safari 继续抛出同样的错误。显然我做错了什么。这甚至是用于Uint8Array
的正确填充物吗?
这是我正在执行的代码(包括 MDN polyfill):
if (!Array.prototype.fill) {
Array.prototype.fill = function(value) {
// Steps 1-2.
if (this == null) {
throw new TypeError('this is null or not defined');
}
var O = Object(this);
// Steps 3-5.
var len = O.length >>> 0;
// Steps 6-7.
var start = arguments[1];
var relativeStart = start >> 0;
// Step 8.
var k = relativeStart < 0 ?
Math.max(len + relativeStart, 0) :
Math.min(relativeStart, len);
// Steps 9-10.
var end = arguments[2];
var relativeEnd = end === undefined ?
len : end >> 0;
// Step 11.
var final = relativeEnd < 0 ?
Math.max(len + relativeEnd, 0) :
Math.min(relativeEnd, len);
// Step 12.
while (k < final) {
O[k] = value;
k++;
}
// Step 13.
return O;
};
}
var x = new Uint8Array(3).fill(42);
console.log(x);
有什么建议吗?谢谢!
(只是重复@Rhumbori的评论,以结束我的问题...
更改这些行
if (!Array.prototype.fill) {
Array.prototype.fill = function(value) {
自
if (!Uint8Array.prototype.fill) {
Uint8Array.prototype.fill = function(value) {
相关文章:
- TypeError:在不兼容的接收器nodejs上调用了方法Uint8Array.length
- Array.prototype.fill() different from fill as I go
- 将image src数据:转换为Uint8Array
- 如何将带偏移量的Uint8Array转换为Int32Array
- 在WebGL着色器中使用UInt8Array数据
- 尝试在画布fill()中填充两种不同的颜色
- Raphael Fill Opacity on member.mouseover
- jQuery 手风琴“heightStyle: fill”,页面加载时显示设置为 none
- Array.prototype.fill() 带有对象传递引用而不是新实例
- 为什么我的 JavaScript toHexString 函数不能在 Uint8Array 中正常工作
- Array.fill 不同于赋值上的文字 2D 定义
- 如何组合两个单独的Uint8Array的颜色数据(JPEG)和透明度数据(PNG)
- 在javascript中将字符串转换为Uint8Array
- Uint16Array to Uint8Array
- Polyfill 基础知识:如何为 Uint8Array.fill 实现 polyfill
- fill lines D3 js
- Firefox操作系统模拟器中的Uint8Array/Uint16Array转换是否已中断
- Javascript: UInt8Array to Float32Array
- Illustrator ExtendScript设置FILL选择的不透明度
- CasperJS-使用fill()与evaluate()与sendKeys()