JavaScript语言精粹笔记

JavaScript语言精粹笔记

  掌握语言的每个特性可以让你出风头,但是并不推荐,因为一部分的特性带来的麻烦可能远超本身的价值。正如书中所言,坏的材料并不能雕刻出好的作品,要成为一名更好的程序员,要取其精华去其糟粕。当你知道要做什么的时候,它还能表现的更好,编程时一件相对困难的事情,绝不应该在懵懂的状态下开始编程之旅。

  JS中的注意为//或者/*content*/,注释一定要精确地描述代码,不然没有用的注释比没有注释更糟糕。

  JS中的代码块不会创建新的作用域,因此变量应该被定义在函数的头部,而不是在代码块中。  

  try语句执行一个代码块,并捕获该代码块抛出的任何异常。catch从句定义一个新的变量来接收抛出的异常对象。 throw语句抛出一个异常,如果在try中,那么流程控制语句跳转到catch从句中,如果在函数中,则该函数调用被放弃,控制流程跳转到调用该函数的try语句的catch从句中

  return语句会导致从函数中提前返回,可以返回指定的值,但是如果没有指定,那么就返回undefined,并且不允许在return关键字和表达式之间换行

  对象是通过引用来传递,他们永远不会被复制。

  原型连接在更新时是不起作用的,当我们对某个对象做出改变时,不会触及对象的原型。只有在检索值的时候才被用到。如果我们尝试去获取对象的某个值的时候,但是该对象没有此属性名,会去寻找原型对象,如果原型对象中也没有,那么再从它的原型中寻找,以此类推,最终到object.prototype。如果属性完全不存在原型链中,那么结果就是undefined,这个过程被称之为委托。

  hasOwnprototype()检测对象是否拥有此属性,该方法不会检查原型链。

for   in属性名的顺序是不确定的,最好的办法就是完全避免使用,而创建一个数组用来保存正确顺序的属性名

  delete删除属性不会触及原型链中的任何对象,可以让来自原型链的属性透现出来。

  JS可以随意的定义全局变量,但是削弱了程序的灵活性,应该避免使用。

  所谓的编程,就是将一组需求分解成一组函数与数据结构的技能。

  JS中的函数就是对象,用键值对的集合并拥有一个链接到原型对象的隐藏链接。对象字面量产生的对象链接到object.prototype。函数对象链接到Function.prototype,这个原型对象本身链接到object.prototype.每个函数没隐式的创建两个属性:函数的上下文和实现函数行为的代码。

  每个函数对象在创建时随配有一个prototype的属性,它的值拥有一个constructor属性且值即为该函数的对象,这个和隐藏链接到Function.prototype完全不同。

  因为函数是对象,所以他们可以像任何其他的值一样被使用。函数可以保存变量,对象和数组。函数可以被当作参数传递给其他函数,函数可以返回函数,并且可以拥有方法。函数的与众不同之处在于它们可以被调用。

  函数字面量可以出现在任何允许表达式出现的地方,函数也可以被定义在其他的函数当中,一个内部函数除了可以访问自己的参数和变量,同时它也能自由访问把它嵌套在其中的父函数的参数与变量。

  通过函数字面量创建的函数对象包含一个链接到外部上下文的连接,称为闭包。

  调用一个函数会暂停执行当前函数,传递控制权和参数给新函数,除了声明时定义的形式参数,每个函数还有两个附加的参数  this 和arguments

  this取决于调用的模式,JS中有4中调用模式:方法调用      函数调用     构造器调用    apply调用,他们在初始化this上存在差异。

  JS中实际参数arguments的个数和形式参数的个数不匹配时候,不会导致运行错误。如果实际参数值过多,会被忽略。过少,缺失的值会被定义为undefined。对参数值不会进行类型检查,任何类型的值都可以被传递给任何参数。

   方法调用模式

  当一个函数被保存为对象的一个属性时,称之为方法,当一个方法被调用的时候,this被绑定到该对象,如果调用表达式包含一个提取属性的动作,那么它就被当作一个方法来调用。方法可以使用this访问自己对象,所以他能从对象中取值或者对对象进行修改。this到对象的绑定发生在调用的时候,这个超级延迟绑定使得函数可以对this高度复用。通过this可以取得他们所属对象的上下文的方法称为公共方法。

    函数调用模式

  当函数并非一个对象的属性时,它就是被当作一个函数来调用。在这个时候,this被绑定到全局对象,这样导致的后果就是方法不能利用内部函数来帮助它工作。因为this绑定了错误的值,所以不能共享该方法对对象的访问权。幸运的是:如果该方法定义一个变量并赋值为this,那么函数的内部函数就可以通过那个变量访问到this,按照约定,那个变量命名为that。

    构造器模式

   JS时一门基于原型继承的语言,对象可以直接从其他对象继承属性。该语言是没有类型的。

   一个函数,如果创建的目的就是希望结合new前缀来调用,那么他就是构造器函数,按照约定,他们保存在以大写格式命名的变量里。如果调用构造器函数前面没有加上new,后果很严重。

    Apply调用模式

  apply方法让我们构建一个参数数组传递给调用函数,允许我们选择this的值,apply方法接收两个参数,都一个时要绑定给this的值,第二个就是一个参数数组。

 

  

时间: 03-30

JavaScript语言精粹笔记的相关文章

javascript语言精粹----笔记【转载】

javascript语言精粹----笔记 1.6种值会为假(==false),分别是false,null,undefined,' ',0,NaN 2.typeof有6种值,分别是'number','string','boolean','undefined','function','object';其中typeof(null),结果是'object' 3.number类型总是64位浮点数,两个整数相除也可能出现非整数结果 4.如果第一个运算数的值为假,那么运算符&&产生它的第一个运算数的值.

javascript 语言精粹 笔记推荐。。

http://www.cnblogs.com/Cohlint/archive/2012/11/26/2788790.html 这篇javascript 语言精粹 学习笔记不错..不过看上去就是读书笔记,没有深入研究某个点..比如闭包..我还是不懂噢.. 比如17条:“add_the_handles 函数目的是给每个时间处理器一个唯一值(i).它未能达到目的是因为事件处理器函数绑定了变量i,而不是函数在构造时的变量i的值.” 这是原书的翻译过来的理解,但是感觉还是很艰涩,不太理解. 闭包这个变量作

JavaScript语言精粹 笔记01

内容比较简单,只是从头梳理一下JS的知识 语法空白标识符数字字符串语句 对象对象字面量检索更新引用原型反射枚举删除减少全局变量污染  语法 1 空白 空白可能表现为格式化字符或注释的形式.空白通常没有意义,但是偶尔必须用它来分割字符序列,否则它们就会被合并成一个单一的符号.例如: var that = this; var 和that之间的空格是不能去掉的,其他的空格都可以被移除. JS提供两种注释: /* */ // 建议使用//,因为/* */中要注释的内容可能包括字符 */ 而报错,例如:

JavaScript语言精粹 笔记03

继承伪类对象说明符原型函数化部件 继承 JS不是基于类的,而是基于原型的,这意味着对象直接从其他对象继承. 1 伪类 JS提供了一套丰富的代码重用模式,它可以模拟那些基于类的模式,因为JS实际上没有类,所以把模拟的类称为伪类.我们可以定义一个构造器并扩充它的原型: var Mammal = function (name) { this.name = name; }; Mammal.prototype.get_name = function ( ) { return this.name; }; M

JavaScript语言精粹 笔记02

函数函数对象函数字面量调用参数返回异常给类型增加方法递归作用域闭包回调模块级联套用记忆   函数 1 函数对象 在JS中函数就是对象.对象是“名/值”对的集合并拥有一个连接到原型对象的隐藏连接.对象字面量产生的对象连接到Object.prototype.函数对象连接到Function.prototype(该原型本身连接到Object.prototype).每个函数在创建时附有两个附加的隐藏属性:函数上下文和实现函数行为的代码. 因为函数是对象,所以它可以像任何其他的值一样被使用.函数可以存放在变

JavaScript语言精粹 笔记06 方法

JS包含了少量可用在标准类型上的标准方法. ArrayFunctionNumberObjectRegExpString Array array.concat(item...) concat方法返回一个新数组,它包含array的浅复制并将1个或多个参数item附加在其后.如果参数item是一个数组,那么他的每个元素会被本别添加. var a = ['a', 'b', 'c']; var b = ['x', 'y', 'z']; var c = a.concat(b, true); // c 是 [

JavaScript语言精粹 笔记05 正则表达式

正则表达式 正则表达式以方法的形式被用于对字符串中的信息进行查找.替换画图提取操作.可处理正则表达式的方法有:regexp.exec, regexp.test,string.match, string.replace, string.search, 和string.split. 结构 有两个方法来创建一个RegExp对象.优先方法是使用正则表达式字面量.正则表达式被包围在一对斜杠中.有3个标志能在RegExp中设置,分别为g.i.m. // 构造一个匹配JavaScript字符串的正则表达式对象

JavaScript语言精粹 笔记04 数组

数组1 数组字面量2 长度3 删除4 列举5 混淆的地方6 方法7 维度 数组1 数组字面量 var empty = []; var numbers = [ 'zero', 'one', 'two', 'three', 'four', 'five', 'six', 'seven', 'eight', 'nine' ]; empty[1] // undefined numbers[1] // 'one' empty.length // 0 numbers.length // 10 数组字面量可以出

JavaScript语言精粹读书笔记- JavaScript对象

JavaScript 对象 除了数字.字符串.布尔值.null.undefined(都不可变)这5种简单类型,其他都是对象. JavaScript中的对象是可变的键控集合(keyed collections). 对象是属性的容器,其中每个属性都拥有名字和值. JavaScript中的对象是无类别的(class-free)的.它对新属性的名字和值没有约束. JavaScript包括一个原型链特性,允许对象继承另一对象的属性. 对象的检索: stooge[“first-name”]或者stooge.