2016-04-21 49 views
0

我有这样的代码:的Javascript连接两个JSON和比较

var json = '[{"id":113,"price":55,"start":"Sun, 24 Apr 2016 00:00:00 +0000","user_id":8},{"title":"","start":"2016-04-25T23:00:00.000Z","price":"115.7"},{"title":"","start":"2016-05-06T23:00:00.000Z","price":"115.7"},{"id":114,"price":45,"start":"Sun, 08 May 2016 00:00:00 +0000","user_id":9},{"title":"","start":"2016-05-08T23:00:00.000Z","price":"115.7"},{"id":111,"price":55,"start":"Wed, 01 Jun 2016 00:00:00 +0000","user_id":11},{"title":"","start":"2016-06-01T23:00:00.000Z","price":"115.7"},{"id":110,"price":53,"start":"Fri, 03 Jun 2016 00:00:00 +0000","user_id":8}]'; 

moment.utc().valueOf(); 

function fulljson(data) { 

    data = jQuery.parseJSON(data); 

    start = moment.utc('Sun, 24 Apr 2016 00:00:00 +0000').valueOf()/86400000; 
    start = parseInt(start); 
    console.log('pocetak'+start); 

    now = moment.utc().valueOf()/86400000; 
    now = parseInt(now); 
    console.log('sada'+now); 

    end = moment.utc('Sun, 05 Jun 2016 00:00:00 +0000').valueOf()/86400000; 
    end = parseInt(end); 
    console.log('kraj'+end); 

    auction_end = parseInt('3'); 
    now = now + auction_end; 
    console.log('a sada je '+now); 

    if (start > now) { 
    pocetak = start; 
    console.log(pocetak); 
    } else { 
    pocetak = now; 
    console.log(pocetak); 
    } 

var array_of_all_dates = []; 
    for (i = pocetak; i < end; i++) { 
    var new_object = { 
        title: '1', 
        start: moment(i*86400000).utcOffset('+0000').format(), 
        price: '{{$article->lowest_bid}}' 
       }; 
    array_of_all_dates.push(new_object); 
} 
document.write(JSON.stringify(array_of_all_dates)); 
    console.log(array_of_all_dates); 
}; 


fulljson(json); 

所以在最后你看,我有jsonarray_of_all_dates。现在我想加入jsonarray_of_all_dates,但如果同一start元素已经excist到array_of_all_dates然后从array_of_all_dates删除它,然后把这个从json ......

http://jsbin.com/qekijumobe/edit?html,js,output

如何做到这一点?请帮忙。

+0

只要是一定的我知道你在问什么。您正尝试** ** ** ** start **属性上的数组。当你找到一个匹配的对象时,你想用'json'数组中相应的对象替换'array_of_all_dates'数组中的那个对象。 这是正确的吗? –

+0

是的,也可以使用array_of_all_dates的日期与moment.utc(json.start).valueOf()/ 86400000相同;从json ...所以你可以比较这两个值 – Andrew

+0

,但你也可以使用从两个开始...比较 – Andrew

回答

0

有一个方便的JavaScript库http://underscorejs.org/,你可以用它来做到这一点。这不完全是加入,但它通过一个循环来完成任务。

_.each(jQuery.parseJSON(json), function(d){  

     console.log(d.start) 
     var idx = _.findIndex(array_of_all_dates, function(ad){ return d.start == ad.start }); 

     if(idx>-1){ 
      array_of_all_dates[idx] = d; 
     } 
    }); 

我注意到那里没有匹配,因为你的日期格式不完全匹配。您可以尝试实例化findIndex谓词中的新时刻对象,并指定特定的日期时间格式。

1

据我理解,解释你的问题

JSON是

[ 
    { 
     "id":113, 
     "price":55, 
     "start":"Sun, 24 Apr 2016 00:00:00 +0000", 
     "user_id":8 
    }, 
    { 
     "title":"", 
     "start":"2016-04-25T23:00:00.000Z", 
     "price":"115.7" 
    }, 
    { 
     "title":"", 
     "start":"2016-05-06T23:00:00.000Z", 
     "price":"115.7" 
    }, 
.. 
} 

而且array_of_all_dates是

[ 
    { 
     "title":"1", 
     "start":"2016-04-24T00:00:00+00:00", 
     "day":16915, 
     "price":100 
    }, 
    { 
     "title":"1", 
     "start":"2016-04-25T00:00:00+00:00", 
     "day":16916, 
     "price":100 
    }, 
    { 
     "title":"1", 
     "start":"2016-04-26T00:00:00+00:00", 
     "day":16917, 
     "price":100 
    }, 
... 
} 

所以,你需要加入这两项,而不必重复“启动“字段。 我的方法会过于合并两个JSON数据对象,并删除重复的开始字段项目。在JQuery中

示例实现:

比方说,你追加两个列表成为一个列表称为mergedItems然后

var uniqueItems = []; 
$.each(mergedItems["start"], function(i, el){ 
    if($.inArray(el, uniqueItems) === -1) uniqueItems.push(el); 
}); 

编辑: 工作实例

http://jsbin.com/vakodahile/edit?html,js,output

+0

你可以请添加这里这里:http://jsbin.com/qekijumobe/edit?html,js,输出...有两个 – Andrew

+0

也从json开始比从数组开始重要... – Andrew

+0

@Andrew。我已经更新了一份工作副本。如果你需要从json开始,那么做json.concat(array) –