为了账号安全,请及时绑定邮箱和手机立即绑定

在InternetExplorer(indexOf、forEach等)中修复JavaScript

/ 猿问

在InternetExplorer(indexOf、forEach等)中修复JavaScript

慕标5265247 2019-07-22 15:29:22

在InternetExplorer(indexOf、forEach等)中修复JavaScriptArray函数

如详细其他地方,而且显然是众所周知的,InternetExplorer(绝对是版本7,在某些情况下,版本8)没有实现关键功能,特别是在Array(如forEachindexOf(等)

这里和那里有许多解决办法,但我希望将一组正确的规范实现折叠到我们的站点中,而不是复制、粘贴或攻击我们自己的实现。我发现JS-方法,这看起来很有希望,但我想我会在这里张贴,看看是否有更强烈的推荐另一个图书馆。若干杂项标准:

  • 对于浏览器已经有实现的那些函数,库应该是不操作的(

    js-methods

    在这里似乎做得很好)。
  • 非-

    GPL

    ,拜托,尽管

    LGPL

    是可以接受的。


查看完整描述

3 回答

?
交互式爱情

许多人使用MDC后备实现(例如。为索引)。它们通常符合严格的标准,甚至可以显式检查所有参数的类型。

不幸的是,虽然很明显,作者认为这段代码是琐碎的和可自由使用的,但似乎没有明确的许可将其写成书面形式。wiki作为一个整体是CC属性-ShareA,如果这是一个可接受的许可(尽管CC不是为代码本身设计的)。

一般情况下,JS-方法看起来没问题,但是在函数应该是什么样的边缘时,它并不是标准兼容的(例如。未定义的列表项、更改列表的函数)。它还包含了其他随机的非标准方法,包括一些可疑的方法,如狡猾的stripTag和不完整的utf-8编解码器(考虑到unescape(encodeURIComponent)戏法)。

至于它的价值,这里是我使用的(我在此发布到公共领域,如果可以说它是可版权的)。它比mdc版本略短一些,因为它不试图键入嗅探您没有做过一些愚蠢的事情,比如PASS非函数回调或非整数索引,但除此之外,它还试图符合标准。(如果我错过了什么,请告诉我。;-)

'use strict';// Add ECMA262-5 method binding if not supported natively//if (!('bind' in Function.prototype)) {
    Function.prototype.bind= function(owner) {
        var that= this;
        if (arguments.length<=1) {
            return function() {
                return that.apply(owner, arguments);
            };
        } else {
            var args= Array.prototype.slice.call(arguments, 1);
            return function() {
                return that.apply(owner, arguments.length===0? args : args.concat(Array.prototype.slice.call(arguments)));
            };
        }
    };}// Add ECMA262-5 string trim if not supported natively//if (!('trim' in String.prototype)) {
    String.prototype.trim= function() {
        return this.replace(/^\s+/, '').replace(/\s+$/, '');
    };}// Add ECMA262-5 Array methods if not supported natively//if (!('indexOf' in Array.prototype)) {
    Array.prototype.indexOf= function(find, i /*opt*/) {
        if (i===undefined) i= 0;
        if (i<0) i+= this.length;
        if (i<0) i= 0;
        for (var n= this.length; i<n; i++)
            if (i in this && this[i]===find)
                return i;
        return -1;
    };}if (!('lastIndexOf' in Array.prototype)) {
    Array.prototype.lastIndexOf= function(find, i /*opt*/) {
        if (i===undefined) i= this.length-1;
        if (i<0) i+= this.length;
        if (i>this.length-1) i= this.length-1;
        for (i++; i-->0;) /* i++ because from-argument is sadly inclusive */
            if (i in this && this[i]===find)
                return i;
        return -1;
    };}if (!('forEach' in Array.prototype)) {
    Array.prototype.forEach= function(action, that /*opt*/) {
        for (var i= 0, n= this.length; i<n; i++)
            if (i in this)
                action.call(that, this[i], i, this);
    };}if (!('map' in Array.prototype)) {
    Array.prototype.map= function(mapper, that /*opt*/) {
        var other= new Array(this.length);
        for (var i= 0, n= this.length; i<n; i++)
            if (i in this)
                other[i]= mapper.call(that, this[i], i, this);
        return other;
    };}if (!('filter' in Array.prototype)) {
    Array.prototype.filter= function(filter, that /*opt*/) {
        var other= [], v;
        for (var i=0, n= this.length; i<n; i++)
            if (i in this && filter.call(that, v= this[i], i, this))
                other.push(v);
        return other;
    };}if (!('every' in Array.prototype)) {
    Array.prototype.every= function(tester, that /*opt*/) {
        for (var i= 0, n= this.length; i<n; i++)
            if (i in this && !tester.call(that, this[i], i, this))
                return false;
        return true;
    };}if (!('some' in Array.prototype)) {
    Array.prototype.some= function(tester, that /*opt*/) {
        for (var i= 0, n= this.length; i<n; i++)
            if (i in this && tester.call(that, this[i], i, this))
                return true;
        return false;
    };}

这里没有实现的其他ECMA 262-5方法包括Arrayreduce/reduceRight,JSON和少数几个新的Object方法,这些方法可以可靠地实现为JS函数。


查看完整回答
反对 回复 2019-07-22
?
喵喔喔

看一看Underscore.js.


查看完整回答
反对 回复 2019-07-22
?
慕姐8265434

已编译了一个小型库,用作浏览器实现中可能缺少的ECMAScript 5函数的垫片。一些功能已经被其他人多次修改,以优化速度并解决浏览器错误。这些函数是为了尽可能严格地遵循规范而编写的。

ES5-shim.js在MIT许可下发布的Array.Prototype扩展接近顶部,您可以分割和删除任何您不需要的功能。我还建议您缩小脚本,因为注释使它比需要的要大得多。


查看完整回答
反对 回复 2019-07-22

添加回答

回复

举报

0/150
提交
取消
意见反馈 邀请有奖 帮助中心 APP下载
官方微信