zoukankan      html  css  js  c++  java
  • Js 基础知识1

    JS比较运算符,有两种比较运算符:

    第一种是==比较,它会自动转换数据类型再比较

    第二种是===比较,它不会自动转换数据类型,如果数据类型不一致,返回false,如果一致,再比较。

    不要使用==比较,始终坚持使用===比较

    浮点数在运算过程中会产生误差,因为计算机无法精确表示无限循环小数。要比较两个浮点数是否相等,只能计算它们之差的绝对值,看是否小于某个阈值:

    Math.abs(1 / 3 - (1 - 2 / 3)) < 0.0000001; // true

    null和undefined

    JavaScript的设计者希望用null表示一个空的值,而undefined表示值未定义。区分两者的意义不大。大多数情况下,我们都应该用nullundefined仅仅在判断函数参数是否传递的情况下有用。

    数组

    数组是一组按顺序排列的集合,集合的每个值称为元素。JavaScript的数组可以包括任意数据类型。例如:

    [1, 2, 3.14, 'Hello', null, true];

    另一种创建数组的方法是通过Array()函数实现:

    new Array(1, 2, 3); // 创建了数组[1, 2, 3]

    数组的元素可以通过索引来访问。索引的起始值为0

    arr[0]; // 返回索引为0的元素,即1
    arr[5]; // 返回索引为5的元素,即true
    arr[6]; // 索引超出了范围,返回undefined

    slice

    slice()的起止参数包括开始索引,不包括结束索引。

    如果不给slice()传递任何参数,它就会从头到尾截取所有元素。利用这一点,我们可以很容易地复制一个Array

    var arr = ['A', 'B', 'C', 'D', 'E', 'F', 'G'];
    var aCopy = arr.slice();
    aCopy; // ['A', 'B', 'C', 'D', 'E', 'F', 'G']
    aCopy === arr; // false

    push和pop :数组尾部插入/删除

    unshift和shift :数组头部插入/删除  unshift添加

    对象

    JavaScript的对象是一组由键-值组成的无序集合 

    var person = {
        name: 'Bob',
        age: 20,
        tags: ['js', 'web', 'mobile'],
        city: 'Beijing',
        'has-Car': true,
        zipcode: null
    };

    访问属性是通过.操作符完成的.

    person.age
    但是如果包含特殊字符,必须使用''访问 , person['has-Car']

    变量

    如果一个变量没有通过var申明就被使用,那么该变量就自动被申明为全局变量

    字符串

    字符串是不可变的,如果对字符串的某个索引赋值,不会有任何错误,但是,也没有任何效果:

    1 var s = 'Test';
    2 s[0] = 'X';
    3 alert(s); 

     条件判断:

    JavaScript把nullundefined0NaN和空字符串''视为false,其他值一概视为true

    for ... of循环和for ... in循环有何区别

    for ... in循环由于历史遗留问题,它遍历的实际上是对象的属性名称。一个Array数组实际上也是一个对象,它的每个元素的索引被视为一个属性

    当我们手动给Array对象添加了额外的属性后,for ... in循环将带来意想不到的意外效果:

    var a = ['A', 'B', 'C'];
    a.name = 'Hello';
    for (var x in a) {
        console.log(x); // '0', '1', '2', 'name'
    }
    console.log(a.length); //3

    for ... in循环将把name包括在内,但Arraylength属性却不包括在内。

    for ... of循环则完全修复了这些问题,它只循环集合本身的元素:

    for (var x of a) {
        console.log(x); // 'A', 'B', 'C'
    }
     
  • 相关阅读:
    后续阶段第二天
    后续阶段第一天
    冲刺第五天
    冲刺第四天
    冲刺第三天
    冲刺第二天
    第二阶段-冲刺第一天
    第一阶段项目总结
    冲刺(7)
    团队开发冲刺第一阶段_6
  • 原文地址:https://www.cnblogs.com/lixiao24/p/10896635.html
Copyright © 2011-2022 走看看