2017-02-11 12 views
0

その型に応じてすべてのデータを新しい配列に保存したいと思います。それが "store"の場合、データはstores []配列に格納する必要があります。型がcustomerの場合、データは顧客配列などに格納する必要があります。Javascriptではかなり新しいので、わかりません私はそれを正しく保管しています。ある配列から別の配列に要素を追加する

var allData = [ 
{type:"store", data:{store_id: 297, name: "Scotiabank - Main Branch", address_id: 1023}}, 
{type:"store", data:{store_id: 614, name: "Scotiabank - Hamilton", address_id: 1984}}, 
{type:"customer", data:{customer_id: 26, store_id:297, first_name: "Dave", last_name: "Bennett", email: "[email protected]", address_id: 4536, add_date: null}}, 
{type:"customer", data:{customer_id: 59, store_id:193, first_name: "John", last_name: "Stevens", email: "[email protected]", address_id: 2473, add_date: null}}, 
{type:"customer", data:{customer_id: 29, store_id:614, first_name: "Sarah", last_name: "Pym", email: "[email protected]", address_id: 1611, add_date: null}}, 
{type:"address", data:{address_id: 1023, address: "2895 Yonge St.", city:"Toronto", province:"ON", postal_code:"L4C02G"}}, 
{type:"address", data:{address_id: 1984, address: "3611 Main St. West", city:"Hamilton", province:"ON", postal_code:"R5O8H5"}}, 
]; 


var CustomerDB = 
{ 
    customer:[], 
    addresses:[], 
    stores:[], 

    add:function insertData (allData) 
    { 
     for (var i = 0; i < allData.length; i++) 
      { 
       if (type =="store") 
        { 
         stores = allData.slice(i); 

        } 
       else if (type == "customer") 
        { 
         customer = allData.slice(i); 
        } 
       else if (type == "address") 
        { 
         addresses = allDara.slice(i); 
        } 
      } 
    } 
} 
allDataアレイ内の各オブジェクトを介し
+1

何 'フィルタ()'については? 'matchedData = allData.filter(data => {store ');});'その後 'stores.push(matchedData);' – mickdev

+0

問題は 'allData.slice(i) 'あなたが要素を削除するので、後続の要素はすべて下にシフトします。これはあなたのインデックス' i'を駄目にします。 – qxz

+0

@mickdev 'stores = stores.append(matchedData);' stores.push(matchedData);ではなく '? – qxz

答えて

4
var CustomerDB = { 
    customer: [], // should be exactly like the type (to make it easier to add) 
    address: [],  // this too (should be adress not adresses) 
    store: [],  // ... 

    add: function insertData(allData) { 
    allData.forEach(function(d) { 
     this[d.type].push(d); 
    }); 
    } 
} 

forEach意志ループ。各項目について、this[d.type]は、customerが正確にthis.customer(顧客用の配列)である場合、this["customer"]と評価されます。

0

あなたはのCustomerDBの外で、あなたの関数を実行しようとすることができます:ここでは

var CustomerDB = 
{ 
    customer:[], 
    addresses:[], 
    stores:[], 
} 

var insertData = function(){ 
    for (var i = 0; i < allData.length; i++) 
    //console.log(allData[i]); 
     { 
      if (allData[i]['type'] == "store") 
       { 
        CustomerDB.stores.push(allData[i]); 

       } 
      else if (allData[i]['type'] == "customer") 
       { 
        CustomerDB.customer.push(allData[i]); 
       } 
      else if (allData[i]['type'] == "address") 
       { 
        CustomerDB.addresses.push(allData[i]); 
       } 
     } 
}(); 

codepen:http://codepen.io/giannidk/pen/egbmRL?editors=0012

関連する問題