0

我有一个有效的 JSFiddle 演示 https://jsfiddle.net/u1fohjxw/

这个想法是基于多个字段创建一个唯一的项目列表。我知道我实现它的方式可以改进,但需要关于在 JSLINQ 中执行它的建议。

这个过滤的唯一列表然后我手动循环并再次添加 - 这可以在 JSLINQ 中完成。

请说明应该如何做:

var myList = [
            {FirstName:"Chris",LastName:"Pearson"},
            {FirstName:"Chris",LastName:"Pearson"},
            {FirstName:"Chris",LastName:"Sutherland"},
            {FirstName:"John",LastName:"Ronald"},
            {FirstName:"Steve",LastName:"Pinkerton"}
            ];


var exampleArray = JSLINQ(myList)
                                    .Distinct(function(item){ return item.FirstName.concat(";",item.LastName)}).items

var newList = [];     

 for (var x = 0 ; x < exampleArray.length ; x++) {
      var arraylist = exampleArray[x].split(";");
      var y= new Object();
     y.FirstName = arraylist[0];
     y.LastName = arraylist[1];
     newList.push(y);
  };                 
4

1 回答 1

2

你好吗?:)

也许这样的事情可以帮助你:

var myList = [
            {FirstName:"Chris",LastName:"Pearson"},
            {FirstName:"Chris",LastName:"Pearson"},
            {FirstName:"Chris",LastName:"Sutherland"},
            {FirstName:"John",LastName:"Ronald"},
            {FirstName:"Steve",LastName:"Pinkerton"}
            ];

var resultList = myList.Distinct(function(x){
                                    return {
                                        FirstName: x.FirstName,
                                        LastName: x.LastName
                                    }
                                }).ToArray();

这将返回在 distinct 中返回的对象数组。

编辑:

将 distinct 方法更改为:

Distinct: function(clause) { 
        var item, dict = {}, retVal = [];
        for (var i = 0; i < this.items.length; i++) {
            item = clause.apply(this.items[i], [this.items[i]]); 
            if (dict[JSON.stringify(item)] === undefined) {
                dict[JSON.stringify(item)] = true;
                retVal.push(item);
            }
        }
        dict = null;
        return JSLINQ(retVal);
    },

它没有经过压力测试,我不知道迭代 10k+ 个对象需要多少时间,但这是需要研究和改进的东西!:)

如果您想尝试,还有另一种可能的解决方法。

干杯!

于 2017-03-22T13:10:30.553 回答