ie11中使用es7的includes

针对Angular6项目中使用ES7的includes方法在IE浏览器上出现的兼容性问题,本文详细介绍了如何通过自定义polyfills来解决此问题,确保在不同浏览器下都能正常运行。

公司前端项目用的是Angular6,最近在项目中用到了es7中数组的新特性includes,在谷歌浏览器正常运行,在IE浏览器运行的时候报错,识别不了includes。一开始的想法就是用indexOf代替一下,转念一想,是否可以做一个兼容,于是自己写了个polyfills,兼容如下:

同时支持String和Array:

// 兼容es7 includes string Array
(function(types) {
    types.forEach(function(type) {
        if (!type.prototype.includes) {
            type.prototype.includes = function(search, start) {
                if (typeof start !== 'number') {
                    start = 0;
                }

                if (start + search.length > this.length) {
                    return false;
                } else {
                    return this.indexOf(search, start) !== -1;
                }
            };
        }
    });
})([String, Array]);

在angular-cli.json中引入就可以了。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值