javascript - IE11 不支持 fill()

标签 javascript reactjs ecmascript-6

我有以下语法。我是 ES6 语法的新手。

const renderLoading = () => Array(20).fill('').map(() => <ExpampleLine/>);

Internet Explorer 不支持 fill() 命令。 fill() 是否有任何解决方法,或者我应该重写整个语法。在语法方面需要一些帮助。

最佳答案

使用 polyfill:

if (!Array.prototype.fill) {
  Object.defineProperty(Array.prototype, 'fill', {
    value: 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;
    }
  });
}

此处提供:https://developer.mozilla.org/en/docs/Web/JavaScript/Reference/Global_Objects/Array/fill?v=example#Polyfill

关于javascript - IE11 不支持 fill(),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43738879/

相关文章:

javascript - 有什么好处! (双不)运算符?

javascript - 如何使用 React Native FlatList 动画重新排序?

ember.js - 使用额外的树在 ember-cli-build 中正确地 babel 转译文件

javascript - 动态搜索栏 - 从 ASP.NET MVC5 中的下拉列表中添加元素

javascript - 我可以在不使用 JS 和 HTML5 的情况下验证 HTML 输入吗?

javascript - 更新 ng-repeat 数组

javascript - 如何将 Firebase Storage 与 Cloud Firestore 连接,以便我的图片与各自的帖子相关联?

javascript - React.js 不会在 setState 上重新渲染

javascript - 添加对象数组javascript的值

javascript - Vue.js:如何在单个文件组件中指定 Prop ?