Javascript / Underscore,将布尔数组转换为字符串数组

时间:2015-04-11 03:04:00

标签: javascript arrays underscore.js

所以我试图将一个布尔数组转换成一个字符串数组(只有被设置为true的布尔值)。这可以是javascript或下划线。让我告诉你我的意思。

我有一个这样的数组:

 [{"item1" : [{"one": true, "two": false}]}, {"item2" : [{"one": false, "two": true}]}];

我正在寻找的最终结果是:

[{"item1" : ["one"]}, {"item2" : ["two"]}];

值得一提的是,所有这些键都是动态的。我似乎无法想象我应该如何遍历此数组来完成此任务。越简单越好!谢谢!

这是我的不良尝试:

  $scope.testObject = _.map($scope.filterArray, function(obj) {

                    _.map(obj.values, function(value) {

                        if (value === true) {
                            return value;
                        }
                    });

                });

(这不起作用)。我想要完成的是将这些对象的值(例如[{“one”:true,“two”:false}]转换为字符串数组,字符串是设置为的项的键真。

所以例如

 [{"one":true, "two": false}]

会变成

  ["one"]

因为两个是假的。

2 个答案:

答案 0 :(得分:6)

使用lodash

1)选择值为truthy的对象的属性:

_.pick(object, Boolean)

2)抓取值为truthy的对象属性的键:(结合上面的解决方案)

_.keys(_.pick(object, Boolean))

3)对item Array.prototype.map进行上述操作(就像在对象上执行_.mapValues(item, function (value) { return _.keys(_.pick(value[0], Boolean)); }); 一样)

var arr = [{"item1" : [{"one":true, "two": false}]}, {"item2" : [{"one":false, "two": true}]}];

function run () {
  return _.map(arr, function (item) {
    return _.mapValues(item, function (value) {
       return _.keys(_.pick(value[0], Boolean));
    });
  })
}

document.write('<pre>' + JSON.stringify(run(), null, 2) + '</pre>')

&#13;
&#13;
<script src="https://cdnjs.cloudflare.com/ajax/libs/lodash.js/3.6.0/lodash.min.js"></script>
&#13;
_.mapValues
&#13;
&#13;
&#13;

更新:使用_.mapValues

幸运的是,大多数方法都受到下划线的支持,我唯一需要做的改变就是将_.mapObject更改为var arr = [{"item1" : [{"one":true, "two": false}]}, {"item2" : [{"one":false, "two": true}]}]; function run () { return _.map(arr, function (item) { return _.mapObject(item, function (value) { return _.keys(_.pick(value[0], Boolean)); }); }) } document.write('<pre>' + JSON.stringify(run(), null, 2) + '</pre>')underscore

&#13;
&#13;
<script src="https://cdnjs.cloudflare.com/ajax/libs/underscore.js/1.8.3/underscore.js"></script>
&#13;
{{1}}
&#13;
&#13;
&#13;

答案 1 :(得分:0)

此功能可让您生成所需的结果。 &#39;对于in&#39;是有用的访问对象键我做了两次。可能有一种更优雅的方式来实现此功能。如果你给我更多信息,我可以试着帮助你吗?&#39;

var arr = [{"item1" : [{"one":true, "two": false}]}, {"item2" : [{"one":false, "two": true}]}];

arr.map(function(item){
    for(key in item){
        for(innerKey in item[key][0]){
            if(item[key][0][innerKey]){
                var obj = {};
                obj[key] = [innerKey];
                return obj;
            } 
        }
    }
});

JavaScript set object key by variable