--- tags: JS - 練習 --- # 【ForEach】和【Map】練習 :::warning ### forEach > forEach() 方法對數組的每個元素執行一次提供的函數。 ### map > map() 方法創建一個新數組,其結果是該數組中的每個元素都調用一個提供的函數後返回的結果。 例如: ``` const result = studentsData.map(item => { return `${ item.name }-${ item.age }歲` }); // 執行結果:result 為 ['王大偉-18歲', '陳小名-24歲'...] ``` ::: > 請用下列資料,data為學校資料: ``` const data = [ { class: '甲', studentsNum: '10', studentsData: [ { id: 1, name: '王大偉', age: 18 }, { id: 2, name: '陳小名', age: 24 }, { id: 3, name: '許世斌', age: 23 }, { id: 4, name: '吳添財', age: 25 }, { id: 5, name: '陳漢霖', age: 66 }, { id: 6, name: '楊采媗', age: 17 }, { id: 7, name: '曾無傭', age: 34 }, { id: 8, name: '楊漢鎮', age: 38 }, { id: 9, name: '楊是崁', age: 35 }, { id: 10, name: '楊安浪', age: 50 } ] }, { class: '乙', studentsNum: '4', studentsData: [ { id: 1, name: '蔡申明', age: 50 }, { id: 2, name: '蔡文旯', age: 51 }, { id: 3, name: '陳炘採', age: 58 }, { id: 4, name: '昂天次', age: 56 }, { id: 5, name: '王銘感', age: 58, interest: ['打球', '唱歌'] } ] }, { class: '丙', studentsNum: '7', studentsData: [ { id: 1, name: '林赤子', age: 18 }, { id: 2, name: '林小優', age: 24 }, { id: 3, name: '陳問鼎', age: 23 }, { id: 4, name: '陳字字', age: 25 }, { id: 5, name: '陳余文', age: 66 }, { id: 6, name: '楊蔡文', age: 17 }, { id: a, name: 'sd32ddd', age: 546 } ] } ] ``` ### ForEach 題目: :::info 甲班的"楊采媗"登入資料填錯了,請將他的年齡改為27歲 ::: :::info 乙班的同學年齡輸入錯誤了,該班級的年齡皆為2*歲,請將班級資料更正 ::: :::info 丙班的同學資料內有人的資料輸入錯誤格式,請將該筆資料的 名稱改為"曾有史",ID修正為"對應筆數",年齡為"28" ::: ### Map 題目: :::info 請將目前學校的班級(甲~丁)存成陣列,並且console出來。 ::: :::info 請將甲班的學生名子console出來,順便將"楊安浪"的年齡改成15歲。 ::: :::info 請將丙班的學生年齡用陣列方式console出來,並將錯誤格式的年齡的回傳直改為"ERROR"字串。 ::: ### 補充練習 題目 (不限制方法): :::info 丁班即將開班,請在學校資料內增加預設資訊 ::: :::info 學校人數越來越多了,校長想統計目前學生總數,請透過迴圈算出總數 ::: :::info 請甲班的學生按照年齡排序 ::: :::info 請從乙班的學生篩選出"昂天次"的資料 ::: :::info 請從學校中的找出"王銘感"該名學生的第一個興趣 ::: :::info 請找出學校資料中錯誤的地方 :::