我在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]);
}
}
})();
我很感激一些指导!
答案 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];
});
解决了我的错误!