作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
这里是 Polyfill 新手。我对这个简单的例子完全感到困惑,在这个例子中我想初始化一个类型化数组:
var x = new Uint8Array(3).fill(42);
console.log(x);
这在 Chrome 和 Firefox 中运行良好:控制台显示 [42, 42, 42]
。 Safari 不支持 fill
方法,会抛出以下错误:“TypeError: new Uint8Array(3).fill is not a function.”
。这是完全有道理的。所以我想我需要实现一个polyfill,对吗?正确的! MDN优惠this one ,但是当我添加这段代码时,没有任何变化: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) {
关于javascript - Polyfill 基础知识 : How to implement a polyfill for Uint8Array. 填充,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34857063/
我是一名优秀的程序员,十分优秀!