美文网首页
(快速入门)条件判断+循环+Map+Set

(快速入门)条件判断+循环+Map+Set

作者: 云木杉 | 来源:发表于2019-03-26 17:43 被阅读0次

    条件判断

    JavaScript使用if () { ... } else { ... }来进行条件判断。

    var age = 20;
    if (age >= 18) { // 如果age >= 18为true,则执行if语句块
        alert('adult');
    } else { // 否则执行else语句块
        alert('teenager');
    }
    

    多行条件判断

    如果还要更细致地判断条件,可以使用多个if...else...的组合:

    var age = 3;
    if (age >= 18) {
        alert('adult');
    } else if (age >= 6) {
        alert('teenager');
    } else {
        alert('kid');
    }
    

    循环

    JavaScript的循环有两种,一种是for循环,通过初始条件、结束条件和递增条件来循环执行语句块:

    var x = 0;
    var i;
    for (i=1; i<=10000; i++) {
        x = x + i;
    }
    

    for ... in

    for循环的一个变体是for ... in循环,它可以把一个对象的所有属性依次循环出来:

    var o = {
        name: 'Jack',
        age: 20,
        city: 'Beijing'
    };
    for (var key in o) {
        console.log(key); // 'name', 'age', 'city'
    }
    

    while

    for循环在已知循环的初始和结束条件时非常有用。而上述忽略了条件的for循环容易让人看不清循环的逻辑,此时用while循环更佳。

    while循环只有一个判断条件,条件满足,就不断循环,条件不满足时则退出循环。比如我们要计算100以内所有奇数之和,可以用while循环实现:

    var x = 0;
    var n = 99;
    while (n > 0) {
        x = x + n;
        n = n - 2;
    }
    x; // 2500
    

    do ... while

    最后一种循环是do { ... } while()循环,它和while循环的唯一区别在于,不是在每次循环开始的时候判断条件,而是在每次循环完成的时候判断条件:

    var n = 0;
    do {
        n = n + 1;
    } while (n < 100);
    n; // 100
    

    Map

    Map和Set是ES6标准新增的数据类型,请根据浏览器的支持情况决定是否要使用。

    Map是一组键值对的结构,具有极快的查找速度。

    举个例子,假设要根据同学的名字查找对应的成绩,如果用Array实现,需要两个Array:

    // array
    var names = ['Michael', 'Bob', 'Tracy'];
    var scores = [95, 75, 85];
    // map
    var m = new Map([['Michael', 95], ['Bob', 75], ['Tracy', 85]]);
    m.get('Michael'); // 95
    

    初始化Map需要一个二维数组,或者直接初始化一个空Map。Map具有以下方法:

    var m = new Map(); // 空Map
    m.set('Adam', 67); // 添加新的key-value
    m.set('Bob', 59);
    m.has('Adam'); // 是否存在key 'Adam': true
    m.get('Adam'); // 67
    m.delete('Adam'); // 删除key 'Adam'
    m.get('Adam'); // undefined
    

    由于一个key只能对应一个value,所以,多次对一个key放入value,后面的值会把前面的值冲掉:

    var m = new Map();
    m.set('Adam', 67);
    m.set('Adam', 88);
    m.get('Adam'); // 88
    

    Set

    Set和Map类似,也是一组key的集合,但不存储value。由于key不能重复,所以,在Set中,没有重复的key。

    要创建一个Set,需要提供一个Array作为输入,或者直接创建一个空Set:

    var s1 = new Set(); // 空Set
    var s2 = new Set([1, 2, 3]); // 含1, 2, 3
    
    // 重复元素在Set中自动被过滤:
    
    var s = new Set([1, 2, 3, 3, '3']);
    s; // Set {1, 2, 3, "3"}
    

    通过add(key)方法可以添加元素到Set中,可以重复添加,但不会有效果:

    s.add(4);
    s; // Set {1, 2, 3, 4}
    s.add(4);
    s; // 仍然是 Set {1, 2, 3, 4}
    
    // 通过delete(key)方法可以删除元素:
    var s = new Set([1, 2, 3]);
    s; // Set {1, 2, 3}
    s.delete(3);
    s; // Set {1, 2}
    

    iterable

    为了统一集合类型,ES6标准引入了新的iterable类型,Array、Map和Set都属于iterable类型。

    for of

    var a = ['A', 'B', 'C'];
    a.name = 'Hello';
    for (var x in a) {
        console.log(x); // '0', '1', '2', 'name'
    }
    
    // for ... in循环将把name包括在内,但Array的length属性却不包括在内。
    
    // for ... of循环则完全修复了这些问题,它只循环集合本身的元素:
    
    var a = ['A', 'B', 'C'];
    a.name = 'Hello';
    for (var x of a) {
        console.log(x); // 'A', 'B', 'C'
    }
    
    

    forEach

    'use strict';
    var a = ['A', 'B', 'C'];
    a.forEach(function (element, index, array) {
        // element: 指向当前元素的值
        // index: 指向当前索引
        // array: 指向Array对象本身
        console.log(element + ', index = ' + index);
    });
    
    // 如果对某些参数不感兴趣,由于JavaScript的函数调用不要求参数必须一致,因此可以忽略它们。例如,只需要获得Array的element:
    
    var a = ['A', 'B', 'C'];
    a.forEach(function (element) {
        console.log(element);
    });
    
    
    

    相关文章

      网友评论

          本文标题:(快速入门)条件判断+循环+Map+Set

          本文链接:https://www.haomeiwen.com/subject/acjnvqtx.html