亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

將名稱分配給數組的數組

將名稱分配給數組的數組

幕布斯6054654 2023-07-06 16:34:54
$(function() {    $.get("https://spreadsheets.google.com/feeds/list/1VC633BXpMElJjRWvIRuZIP7UrEhuw6BdscnrV2heox0/1/public/full?alt=json", function(data) {    var entry = data.feed.entry;    var getKeys = Object.keys(entry[0]).slice(6);    arr = getKeys.map(title => {      return entry.map((el) => {        return el[title].$t;      }).filter((el) => {        return el.trim();      });    });    console.log(getKeys);    console.log(arr);  });});<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>上面的代碼會將谷歌工作表中的數據返回到數組數組中。getKeys我一直堅持為每個組分配值arr以返回新的 arr 值:var arr = [  gsx$fruits = ["apple", "banana"],   gsx$animals = ["monkey", "dog", "cat", "bear"],   gsx$numbers = ["one", "two", "three", "four"]]...這樣我就可以不僅通過索引位置訪問特定組。感謝您的幫助!
查看完整描述

2 回答

?
狐的傳說

TA貢獻1804條經驗 獲得超3個贊

我做了一些大修改,但這里有另一種選擇:


$(async function() {

  const data = await $.get("https://spreadsheets.google.com/feeds/list/1VC633BXpMElJjRWvIRuZIP7UrEhuw6BdscnrV2heox0/1/public/full?alt=json");

  

  const arrays = {};

  for (const entry of data.feed.entry) {

    for (const key in entry) {

      if (key.slice(0, 4) != "gsx$") continue;

      if (!entry[key].$t.trim()) continue;


      const name = key.slice(4); // optional, you could also use `key`

      if (!arrays[name]) arrays[name] = [];

      arrays[name].push(entry[key].$t);

    }

  }

  

  console.log(arrays);

});

<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>


該解決方案首先創建一個arrays將保存不同數組的對象。然后,我循環遍歷這兩個data.feed.entry值,并且對于每個條目,我將循環遍歷鍵。如果key不以開頭"gsx$"或者修剪后關聯值為空字符串,我將跳到下一次迭代。

如果我們沒有跳過,請刪除前 4 個字符key并將這個新值分配給name(可選)。然后檢查是否arrays包含該屬性name,如果不包含則將其分配arrays[name]給空數組。

最后將值壓入數組。

我試圖讓這個答案易于理解,如果您有任何問題,請不要害怕發表評論。


查看完整回答
反對 回復 2023-07-06
?
繁花不似錦

TA貢獻1851條經驗 獲得超4個贊

首先你需要知道的是javaScript中的數組只是對象的一種特殊形式,而索引是整數類型的屬性名稱,因此如果你不僅想通過索引訪問數組中的元素,還想通過屬性名稱訪問數組中的元素,你可以使用計算屬性將這些值映射到不同的名稱。


const keys = ['fruits', 'animals', 'numbers']

const data = [

  ["apple", "banana"],

  ["monkey", "dog", "cat", "bear"],

  ["one", "two", "three", "four"]

];


data.forEach((item, index, array) => array[keys[index]] = item);


console.log(data);

console.log(data[0]);

console.log(data['fruits']);


雖然它可以解決您的問題,但它會改變原始數組。如果您需要訪問具有屬性名稱的元素,我建議您使用另一種數組方法reduce,這樣您可以獲得新形式的數據,并且保持原始數組不變。


const keys = ['fruits', 'animals', 'numbers']

const data = [

  ["apple", "banana"],

  ["monkey", "dog", "cat", "bear"],

  ["one", "two", "three", "four"]

];



const newFormData = data.reduce((acc, cur, index) => {

  return { ...acc,

    [keys[index]]: cur

  }

}, {});


console.log(data);

console.log(newFormData);


查看完整回答
反對 回復 2023-07-06
  • 2 回答
  • 0 關注
  • 166 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號