使用IE浏览器的Angular工厂/服务中出现两个错误,但Chrome或Edge中没有错误

时间:2017-01-12 09:41:48

标签: javascript angularjs google-chrome internet-explorer angular-services

我在IE中遇到2个错误,我没有使用Chrome或Edge。

可能是特定代码和IE的兼容性问题,或者可能是我的代码本身导致了错误。

第一个错误:

语法错误(无特定):在这行代码中:

var groupedArray = Object.keys(groupedObj).sort().map(key=>groupedObj[key]); 

第二个错误:

错误:[$ injector:unpr]未知提供者:GroupDateRangeServiceProvider< - GroupDateRangeService< - SocialMentionsAnalysisController

就像我提到的,我不会在Chrome和Edge中出现这些错误,但我更愿意让网站与IE用户兼容。

以下是我的Angular工厂/服务的完整代码:

(function () {
    'use strict';

    angular
        .module('portalDashboardApp')
        .factory('GroupDateRangeService', GroupDateRangeService);

    GroupDateRangeService.$inject = [];

    function GroupDateRangeService() {

        var service = {
            createArray: createArray,
            setItemCount: setItemCount,
            setSeries: setSeries
        };

        return service;

        function createArray(dateArray, valueArray) {
            var arr = dateArray.map(function (s) {
                var week = getWeekNumber(parseISOLocal(s));
                return week[0] + ('0' + week[1]).slice(-2) + ':' + s;
            }).sort();
            var results = createGroupedArray(createGroupObject(arr));
            if (valueArray && valueArray.length === dateArray.length) {
                for (var i = 0; i < results.length; i++) {
                    results[i] = results[i].map(function (date, index) {
                        var obj = {};
                        obj[date] = valueArray[index];

                        return obj;
                    });
                }
            }

            var arrayOfWeeks = results;
            return results;
        }

        // Create a Total Count
        function setItemCount(dataSet) {
            var itemCount = 0;
            angular.forEach(dataSet, function (dataItem) {
                itemCount = itemCount + dataItem.Total;
            });
            return itemCount;
        };

        // Create Chart Series
        function setSeries(dataSet, type) {
            var series = [{
                name: 'Items',
                data: [],
                showInLegend: false
            }];
            angular.forEach(dataSet, function (dataItem, dataIndex) {
                if (type === 'Count') {
                    series[0].data[dataIndex] = [dataItem.Description, dataItem.Total];
                }
                else if (type === 'Percentage') {
                    series[0].type = 'pie';
                    series[0].innerSize = '40%';
                    series[0].data[dataIndex] = [dataItem.Description, dataItem.Percentage];
                }
                else if (type === 'Adspend') {
                    series[0].data[dataIndex] = [dataItem.Description, dataItem.Adspend];
                }
            });
            return series;
        };

        function createGroupObject(arr) {

            var groupedObj = arr.reduce(function (result, value) {

                var b = value.split(':');

                if (!result[b[0]]) result[b[0]] = [];
                result[b[0]].push(b[1]);

                return result;

            }, {});

            return groupedObj;
        }

        function createGroupedArray(groupedObj) {

            // Grab arrays in order of week number. Sort keys to maintain order
            var groupedArray = Object.keys(groupedObj).sort().map(key=>groupedObj[key]);

            // Final set of grouped dates
            console.log(groupedArray.join('\n\n'));

            return groupedArray;

        }

        /* Helper to get the ISO week number of a date
        ** @param {Date} date to get week of
        ** @returns {Array} [year, weekNumber]
        */
        function getWeekNumber(d) {
            d = new Date(+d);
            d.setHours(0, 0, 0, 0);
            d.setDate(d.getDate() + 4 - (d.getDay() || 7));
            var yearStart = new Date(d.getFullYear(), 0, 1);
            var weekNo = Math.ceil((((d - yearStart) / 86400000) + 1) / 7);
            return [d.getFullYear(), weekNo];
        }

        /* Parse ISO 8601 format date string to local date
        ** @param {string} s - string to parse like 2016-12-15
        ** @returns {Date}
        */
        function parseISOLocal(s) {
            var b = s.split(/\D/);
            return new Date(b[0], b[1] - 1, b[2]);
        }
    }

})();

我很感激一些指导!

1 个答案:

答案 0 :(得分:0)

这是zeroflagL的解决方案:

我的问题是在我的服务/工厂中使用ES2015 JavaScript代码。这与IE无法比拟,它在2年内没有发布新版本。

所以,改变

var groupedArray = Object.keys(groupedObj).sort()
    .map(key=>groupedObj[key]);

var groupedArray = Object.keys(groupedObj).sort()
    .map(function (key) {
        return groupedObj[key];
    });

解决了我的错误!