前端开发让前端飞Web前端之路

JavaScript30 Day 4(数组操作)

2017-07-27  本文已影响55人  lijianliang

这是我在github 上发现的一个原生js挑战项目,由于是js小白,希望通过这次的项目加深对js的理解

第4天主要是一些关于数组的操作
*filter

新的调试方式

以往我们习惯于用console,log()来输出,本次练习出现了console.table()这种新方式,将数据以表格的形式显示

效果图

js数组的操作(重点)

function isBigEnough(value) {
  return value >= 10;
}

var filtered = [12, 5, 8, 130, 44].filter(isBigEnough);

// filtered is [12, 130, 44]

// ES6 way

const isBigEnough = value => value >= 10;//类似function(value){return value>=10}

let [...spraed]= [12, 5, 8, 130, 44];//...代表不定参数

let filtered = spraed.filter(isBigEnough);

// filtered is [12, 130, 44]

该例子是筛选出数组中大于10的元素

// 使用三个参数

const numbers = [1, 2, 3, 4, 5];

let arr = numbers.map((currentValue, index, array) => {
    console.log(`currentValue = `, currentValue);
    console.log(`index = `, index);
    console.log(`array= `, array);
    return currentValue * 2;
}, numbers);

console.log(`arr `, arr);



let numbers = [1, 5, 10, 15];
let doubles = numbers.map((x) => {
   return x * 2;
});

// doubles is now [2, 10, 20, 30]
// numbers is still [1, 5, 10, 15]


let numbers = [1, 4, 9];
let roots = numbers.map(Math.sqrt);

// roots is now [1, 2, 3]
// numbers is still [1, 4, 9]
//即map()不改变原数组
var fruit = ['cherries', 'apples', 'bananas'];
fruit.sort(); 
// ['apples', 'bananas', 'cherries']

var scores = [1, 10, 21, 2]; 
scores.sort(); 
// [1, 10, 2, 21]
// 注意10在2之前,
// 因为在 Unicode 指针顺序中"10"在"2"之前

var things = ['word', 'Word', '1 Word', '2 Words'];
things.sort(); 
// ['1 Word', '2 Words', 'Word', 'word']
// 在Unicode中, 数字在大写字母之前,
// 大写字母在小写字母之前.

如果想要升序或者降序,我们需要价格比较函数,例如

function compareNumbers(a, b) {
  return a - b;
}
var total = [0, 1, 2, 3].reduce(function(sum, value) {
  return sum + value;
}, 0);
// total is 6

以上就是我在day4中学到的知识,这里我参考了soyaine的中文指南

上一篇 下一篇

猜你喜欢

热点阅读