Angular 4 приложения, использующие IE 11, "Не удается выполнить код из освобожденного script"

У меня есть приложение Angular, которое, по моему мнению, является версией 4. IE 11 сбой во время последовательности входа в этом приложении: "Невозможно выполнить код из освобожденного script". В соответствии с консолью IE ошибка возникает в пакете polyfills в строке 10939 ( "var testString = delegate.toString()" ), которая выглядит следующим образом:

  var checkIEAndCrossContext = function (nativeDelegate, delegate, target, args) {
    if (!isDisableIECheck && ieOrEdge) {
        if (isEnableCrossContextCheck) {
            try {
                var testString = delegate.toString();
                if ((testString === FUNCTION_WRAPPER || testString == BROWSER_TOOLS)) {
                    nativeDelegate.apply(target, args);
                    return false;
                }
            }
            catch (error) {
                nativeDelegate.apply(target, args);
                return false;
            }
        }
        else {
            var testString = delegate.toString();   // <===== HERE!
            if ((testString === FUNCTION_WRAPPER || testString == BROWSER_TOOLS)) {
                nativeDelegate.apply(target, args);
                return false;
            }
        }
    }
    else if (isEnableCrossContextCheck) {
        try {
            delegate.toString();
        }
        catch (error) {
            nativeDelegate.apply(target, args);
            return false;
        }
    }
    return true;
};

Я думаю, что это из этой строки в файле polyfills:

 /* Zone JS is required by Angular itself.*/
 import 'zone.js/dist/zone';  // Included with Angular CLI.

Это из пакета package.json относительно zone.js:

"zone.js": "^0.8.4"

Файл polyfill.ts:

/**
 * This file includes polyfills needed by Angular and is loaded before the app.
 * You can add your own extra polyfills to this file.
 *
 * This file is divided into 2 sections:
 *   1. Browser polyfills. These are applied before loading ZoneJS and are sorted by browsers.
 *   2. Application imports. Files imported after ZoneJS that should be loaded before your main
 *      file.
 *
 * The current setup is for so-called "evergreen" browsers; the last versions of browsers that
 * automatically update themselves. This includes Safari >= 10, Chrome >= 55 (including Opera),
 * Edge >= 13 on the desktop, and iOS 10 and Chrome on mobile.
 *
 * Learn more in https://angular.io/docs/ts/latest/guide/browser-support.html
 */

/***************************************************************************************************
 * BROWSER POLYFILLS
 */

/** IE9, IE10 and IE11 requires all of the following polyfills. **/
import 'core-js/es6/symbol';
import 'core-js/es6/object';
import 'core-js/es6/function';
import 'core-js/es6/parse-int';
import 'core-js/es6/parse-float';
import 'core-js/es6/number';
import 'core-js/es6/math';
import 'core-js/es6/string';
import 'core-js/es6/date';
import 'core-js/es6/array';
import 'core-js/es6/regexp';
import 'core-js/es6/map';
import 'core-js/es6/weak-map';
import 'core-js/es6/set';

/** IE10 and IE11 requires the following for NgClass support on SVG elements */
 import 'classlist.js';  // Run `npm install --save classlist.js`.

/** IE10 and IE11 requires the following to support `@angular/animation`. */
 import 'web-animations-js';  // Run `npm install --save web-animations-js`.


/** Evergreen browsers require these. **/
import 'core-js/es6/reflect';
import 'core-js/es7/reflect';


/** ALL Firefox browsers require the following to support `@angular/animation`. **/
 import 'web-animations-js';  // Run `npm install --save web-animations-js`.



/***************************************************************************************************
 * Zone JS is required by Angular itself.
 */
import 'zone.js/dist/zone';  // Included with Angular CLI.



/***************************************************************************************************
 * APPLICATION IMPORTS
 */

/**
 * Date, currency, decimal and percent pipes.
 * Needed for: All but Chrome, Firefox, Edge, IE11 and Safari 10
 */
// import 'intl';  // Run `npm install --save intl`.
/**
 * Need to import at least one locale-data with intl.
 */
// import 'intl/locale-data/jsonp/en';

import 'hammerjs/hammer';

Что бы вы порекомендовали мне в этом случае?

Ответ 1

Одним из решений является установка переменной isEnableCrossContextCheck в true, поэтому IE должен запускать код, содержащий блок try/catch, который может обрабатывать ошибку.

        if (isEnableCrossContextCheck) {
            try {
                var testString = delegate.toString();
                if ((testString === FUNCTION_WRAPPER || testString == BROWSER_TOOLS)) {
                    nativeDelegate.apply(target, args);
                    return false;
                }
            }
            catch (error) {
                nativeDelegate.apply(target, args);
                return false;
            }
        }
        else {
            var testString = delegate.toString(); 
            if ((testString === FUNCTION_WRAPPER || testString == BROWSER_TOOLS)) {
                nativeDelegate.apply(target, args);
                return false;
            }
        }

В этом сообщении показано, как к этому:

Angular 4 поместите глобальную константу в зону zone.js

Ответ 2

Просто используйте приведенный ниже код для устранения ошибок zone.js в версиях IE 11/EDGE. Следующий код должен быть помещен в polyfills.ts:

if (document['documentMode'] || /Edge/.test(navigator.userAgent)) {
    (window as any).__Zone_enable_cross_context_check = true;
}

Внесите изменения в приведенный выше код в соответствии с вашими требованиями.

Ответ 3

Начиная с версии Angular 7.x, я удалил комментарий из (window as any).__Zone_enable_cross_context_check = true; в polyfill.ts и перекомпилировали проект.

Ответ 4

Согласно этой теме фактическое исправление - ничего не делать ! Эта ошибка возникает только тогда, когда DevTools открыты в IE, что в основном означает, что это происходит только тогда, когда вы ищете его. IE просто замечательный, не так ли?

Закрытие DevTools (как это делают почти все при просмотре веб-сайта) не приведет к возникновению этой ошибки.

Вышеуказанные исправления могут быть применены для тестирования или среды разработки, если это необходимо, но в идеале не следует применять их к производственной среде, поскольку это просто добавляет некоторые дополнительные издержки, которые не нужны.