第一部分 JavaScript语言核心

Posted 珞珞如石

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了第一部分 JavaScript语言核心相关的知识,希望对你有一定的参考价值。

第六章 对象

  • P123 在ES3中,点运算符后的标识符不能是保留字。如果一个对象的属性名是保留字,name必须使用方括号的形式访问它们,如o["for"]和o["class"]。ES5可以在点运算符后直接使用保留字。
  • P123 JS对象都是关联数组:数组元素通过字符串索引而不是数字索引,也称散列、映射或字典。
  • P141 JSON.stringify(o);//序列化 JSON.parse(o);//还原 同时使用用于深拷贝

第七章 数组

  • P146 非负整数索引被当做数组索引,其他被当做对象属性。数组索引仅是对象属性名的一种特殊形式,这意味着JS数组没有"越界"错误的概念。查询不存在属性返回undefiend。

    a[-1.23] = true;//创建名为“-1.23”的属性
    a["1000"] = 0;//数组的第1001个元素
    a[1.000]//等价于a[1]
  • P147 足够稀疏的数组通常在实现上比稠密的数组更慢、内存利用率更高,在这样的数组中查找元素的时间与常规对象查找时间一样长。为什么?

    ? 在数组直接量中省略值时部位稀疏数组。省略值为undefined。可用in操作符监测两者区别:

    a1 = [,,,];
    a2 = new Array(3);
    0 in a1;//true,a1在索引0处有一个元素undefiend,测试为false,省略值不存在 嗯?
    0 in a2;//false
  • P161 类数组对象

第八章 函数

  • p173 函数定义中使用注释optional来强调形参是可选的。

  • P174 通过实参对象(不是数组)arguments[num]获得传入的实参,length属性获得实参个数。可变长实参列表:

    /*可变长实参列表,返回最大值为例:*/
    function max(/*...*/){
        var max = Number.NEGATIVE_INFINITY;
        //遍历实参,查找并记住最大值
        for(var i = 0; i < arguments.length; i++)
            if (argument[i] > max) amx = argument[i];
        return max;
    }
    
    var largest = max(1,1000,2,5000,4,5,6); // =>5000
  • P176 可将对象属性用作实参,为了实参不必按照顺序。

  • P182 闭包

    var scope = "gloval scope"; //全局
    function checkscope(){
        var scope = "local scope";  //局部
        function f(x){ return scoped; }
        return f;
    }
    checkscope()()  //返回"local scope"

    词法作用域基本规则:JS函数的执行用到了作用域链,这个作用域链是函数定义的时候创建的。嵌套的韩式f(x)定义在这个作用域链里面,其中的变量scope一定是局部变量,不管在何时何地执行f(),这种绑定在其执行时依然有效。

    Js词法作用域规则

    1、函数允许访问函数外的数据

    2、整个代码结构中只有函数可以限定作用域

    3、作用域规则首先使用提升规则分析

    4、如果当前作用域中有了该变量, 就不考虑外面的同名变量

以上是关于第一部分 JavaScript语言核心的主要内容,如果未能解决你的问题,请参考以下文章

JavaScript设计模式与开发实践第一部分

几个非常实用的JQuery代码片段

你可能不知道的JavaScript代码片段和技巧(下)

你可能不知道的JavaScript代码片段和技巧(上)

译文:18个实用的JavaScript代码片段,助你快速处理日常编程任务

常用Javascript代码片段集锦