使用ES6新數組方法(象C# Lambda表達式一樣寫查詢語句)


let people = [
    {id: 1, name: "a", age: 12}, 
    {id: 2, name: "b", age: 13}, 
    {id: 3, name: "c", age: 14}, 
    {id: 4, name: "d", age: 15}, 
    {id: 5, name: "e", age: 16}
];

const kids = [];
people.forEach(person => {
    if (person.age < 15) {
        kids.push({
            id: person.id,
            name: person.name
        })
    }
});
console.log(kids);

//map & filter都是數組的方法!
//返回項參與的表達式值
const numbers = [1, 2, 3, 4, 5];
const doubled = numbers.map(number => number * 2); //[2,4,6,8,10]
console.log(doubled);

//返回滿足條件的項
const even = numbers.filter(number => number % 2 === 0); //[2,4]
console.log(even);

//把用forEach示例重寫
const kids2 = people
    .filter(person => person.age < 15)
    .map(person => ({
        id: person.id,
        name: person.name
    }));
console.log(kids2);

/*
結論:從上面的示例可知,filter相當於C#的where過濾條件,map相當於C#的select投影
*/

  


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM