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。

JavaScript语言精粹笔记

    构造器模式

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

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

    Apply调用模式

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

JavaScript语言精粹笔记 

  参数

  当函数被调用的时候,会自动传入一个参数,arguments,函数可以通过这个参数访问所有它调用时传递给它的参数列表。JavaScript语言精粹笔记

  通过给object.prototype添加方法,可以让该方法对所有对象使用。

  作用域的好处时内部函数可以访问定义他们外部函数的参数和变量。JavaScript语言精粹笔记

  闭包:函数可以访问它被创建时所处的上下文环境。

  可以使用函数和闭包来构造模块,模块时一个提供接口却隐藏状态与实现函数或对象,通过函数产生模块,我们几乎可以完全屏蔽全局变量的使用,从而缓解全局变量的滥用。模块模式利用了函数作用域和闭包来创建被绑定对象与私有成员的关联。JavaScript语言精粹笔记

  模块时一个提供接口却隐藏状态与实现的函数或者对象。可以通过函数和闭包来构建模块。

  模块的一般形式时:一个定义了私有变量和函数的很熟;利用闭包创建可以访问私有变量的和函数的特权函数,最后返回这个特权函数,或者把它保存到一个可以访问到的地方。

  利用闭包创建可以访问私有变量和函数的特权函数,最后返回这个特权函数,或者把他们保存到一个可以访问的地方。使用模块模式就可以摒弃全局变量的使用。

  模块可以用来产生安全的对象。

  //返回一个用俩产生唯一字符串的对象

  JavaScript语言精粹笔记

  级联就是每个方法返回的是对象,并且每个调用的结果可以被下一次调用所用。

  EG:$().getId(''X).css('x','x').html(x);

  柯里化允许我们把函数传递给他的参数相结合,产生一个新的函数。

  

上一篇:vs2017 新建Class 文件时,自动添加作者版权声明注释


下一篇:2020年腾讯实习生C++面试题&持续更新中(2)