--- tags: JS - 練習 --- # 【Filter】、【Find】過濾 練習 :::warning ### filter > filter() 方法創建一個新的數組,新數組中的元素是通過檢查指定數組中符合條件的所有元素。 例如: ``` const result = studentsData.filter(item => item.age >= 18); // 執行結果:result 為 [ { name: '王大偉', age: '18'}, { name: '陳小名', age: '24'}... ] const result = studentsData.filter(item => item.age >= 70); // 執行結果:result 為 [] ``` ### find > find() 方法返回數組中滿足提供的測試函數的第一個元素的值。否則返回 undefined。 例如: ``` const result = studentsData.find(item => item.age >= 18); // 執行結果:result 為 { name: '王大偉', age: '18'} const result = studentsData.find(item => item.age >= 70); // 執行結果:result 為 undefined ``` ::: > 請用下列資料,data為學校資料: ``` const data = [ { class: '甲', studentsNum: '10', studentsData: [ { id: 1, name: '王大偉', age: 18, interest: ['聽音樂', '唱歌', '看書'] }, { id: 2, name: '陳小名', age: 24, interest: ['打球', '聽音樂'] }, { id: 3, name: '許世斌', age: 23, interest: ['唱歌', '聽音樂'] }, { id: 4, name: '吳添財', age: 25, interest: ['打球', '聽音樂'] }, { id: 5, name: '陳漢霖', age: 66, interest: ['喝酒', '唱歌', '看書'] }, { id: 6, name: '楊采媗', age: 17, interest: ['打球', '唱歌'] }, { id: 7, name: '曾無傭', age: 34, interest: ['打球'] }, { id: 8, name: '楊漢鎮', age: 38, interest: ['看書', '唱歌'] }, { id: 9, name: '楊是崁', age: 35, interest: ['看書'] }, { id: 10, name: '楊安浪', age: 50, interest: ['聽音樂', '唱歌', '看書'] } ] }, { class: '乙', studentsNum: '5', studentsData: [ { id: 1, name: '蔡申明', age: 50, interest: ['打球', '唱歌', '看書'] }, { id: 2, name: '蔡文旯', age: 51, interest: ['唱歌', '看書'] }, { id: 3, name: '陳炘採', age: 58, interest: ['打球'] }, { id: 4, name: '昂天次', age: 56, interest: ['聽音樂', '唱歌', '看書'] }, { id: 5, name: '王銘感', age: 58, interest: ['聽音樂'] } ] }, { class: '丙', studentsNum: '6', studentsData: [ { id: 1, name: '林赤子', age: 18, interest: ['唱歌'] }, { id: 2, name: '林小優', age: 24, interest: ['聽音樂', '唱歌', '看書'] }, { id: 3, name: '陳問鼎', age: 23, interest: ['打球', '唱歌', '看書'] }, { id: 4, name: '陳字字', age: 25, interest: ['打球', '唱歌', '聽音樂'] }, { id: 5, name: '陳余文', age: 66, interest: ['聽音樂', '唱歌', '看書'] }, { id: 6, name: '楊蔡文', age: 17, interest: ['打球', '聽音樂'] } ] } ] ``` ### Filter 題目: :::info 請將甲班的姓"楊"的同學篩選出來 ::: :::info 請將丙班的同學年齡大於30歲的同學篩選出來 ::: :::info 請將所有班級姓"陳"且年齡大於20歲的同學篩選出來,並放在同一個陣列 ::: :::info 請將甲班喜歡"聽音樂的人篩選出來" ::: ### Find 題目: :::info 請將甲班的姓"許"的第一個同學篩選出來 ::: :::info 請將乙班的同學興趣為打球的學生篩出來 ::: :::info 判斷該學校中是否有戊班 ::: ### 補充練習 題目 (不限制方法): :::info 請整理出甲班大於20歲,且喜歡"打球"的同學篩選出來 ::: :::info 請整理出學校學生興趣是"看書"且興趣是三個的同學 :::