javascript - 扩展 Angular 服务/工厂以获取日期数组和整数数组,并创建带有键值对的数组

标签 javascript angularjs arrays angular-services

我有一个服务/工厂,它接受一个日期数组,并根据 ISO 周将其分组到一个数组 [[],[]] 数组中。此功能按预期工作。

但是我如何扩展服务/工厂以获取另一个值数组(只是普通整数值),并创建每个日期和值的键值对。仍然是数组数组的相同输出格式吗?

这是我的服务/工厂电话:

$scope.weeks = GroupDateRangeService.createArray(timeline_data, time_trend);

传递给服务的数据如下所示:

timeline_data: ["2017-01-04","2017-01-05","2017-01-06","2017-01-07","2017-01-08","2017-01-09","2017-01-10","2017-01-11"]

time_trend: [566, 607, 430, 357, 277, 591, 711, 206]

结果看起来像这样:

result: [["2017-01-04": 566,"2017-01-05": 607,"2017-01-06": 430,"2017-01-07": 357,"2017-01-08": 277], ["2017-01-09": 591,"2017-01-10": 711,"2017-01-11": 206]]

这是我的服务/工厂:

(function () {
    'use strict';

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

    GroupDateRangeService.$inject = [];

    function GroupDateRangeService() {

        var service = {
            createArray: createArray,
        };

        return service;

        function createArray(data) {
            var arr = data.map(function (s) {
                var week = getWeekNumber(parseISOLocal(s));
                return week[0] + ('0' + week[1]).slice(-2) + ':' + s;
            }).sort();
            return createGroupedArray(createGroupObject(arr));
        };

        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]);

            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]);
        }
    }

})();

非常感谢您的指导!

最佳答案

你的结果不能是这样的,数组不能有键值对。它必须是对象数组的数组。如果您重构函数以接受第二个参数,您可以执行以下操作:

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

您的结果应该如下所示:

result: [[{"2017-01-04": 566},{"2017-01-05": 607},{"2017-01-06": 430},{"2017-01-07": 357},{"2017-01-08": 277}], [{"2017-01-09": 591},{"2017-01-10": 711},{"2017-01-11": 206}]]

关于javascript - 扩展 Angular 服务/工厂以获取日期数组和整数数组,并创建带有键值对的数组,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41591662/

相关文章:

c - 正确检索 C 结构中的指针字段

javascript - JS 中的动态变量

javascript - 调用方法时出错 'addReservation' : Internal server error [500]

javascript - Breeze 实体查询是否仍支持 withParameters?

javascript - Maquette 的 createMapping() 参数的 updateTarget 函数中发生了什么?

Javascript 如何拆分 JSON 数组,找到数字中的最大值,然后获取与其对应的名称?

javascript - 如何使用工具栏选项在 Quill js 上添加字体类型?

javascript - browserify 使用 react-router 加载 ReactJS 两次

javascript - 将实际对象传递给事件函数

javascript - 谷歌地图标记类别过滤不起作用?