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的值,第二个就是一个参数数组。

 

  参数

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

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

  作用域的好处时内部函数可以访问定义他们外部函数的参数和变量。

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

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

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

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

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

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

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

  

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

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

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

  

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

  1. JavaScript 语言精粹笔记3

    方法 毒瘤 糟粕 记录一下阅读蝴蝶书的笔记,本篇为书中最后一部分:方法.代码风格.优美的特性.毒瘤.糟粕等. 方法 这一章主要介绍了一些方法集.这里写几个我不太熟悉的方法和要点吧. array.joi ...

  2. JavaScript语言精粹 笔记06 方法

    JS包含了少量可用在标准类型上的标准方法. ArrayFunctionNumberObjectRegExpString Array array.concat(item...) concat方法返回一个 ...

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

    正则表达式 正则表达式以方法的形式被用于对字符串中的信息进行查找.替换画图提取操作.可处理正则表达式的方法有:regexp.exec, regexp.test,string.match, string ...

  4. JavaScript语言精粹 笔记04 数组

    数组1 数组字面量2 长度3 删除4 列举5 混淆的地方6 方法7 维度 数组1 数组字面量 var empty = []; var numbers = [ 'zero', 'one', 'two', ...

  5. JavaScript语言精粹 笔记03 继承

    继承伪类对象说明符原型函数化部件 继承 JS不是基于类的,而是基于原型的,这意味着对象直接从其他对象继承. 1 伪类 JS提供了一套丰富的代码重用模式,它可以模拟那些基于类的模式,因为JS实际上没有类 ...

  6. JavaScript语言精粹 笔记02 函数

    函数函数对象函数字面量调用参数返回异常给类型增加方法递归作用域闭包回调模块级联套用记忆   函数 1 函数对象 在JS中函数就是对象.对象是“名/值”对的集合并拥有一个连接到原型对象的隐藏连接.对象字 ...

  7. JavaScript语言精粹 笔记01 语法 对象

    内容比较简单,只是从头梳理一下JS的知识 语法空白标识符数字字符串语句 对象对象字面量检索更新引用原型反射枚举删除减少全局变量污染  语法 1 空白 空白可能表现为格式化字符或注释的形式.空白通常没有 ...

  8. 1.javascript语言精粹笔记

    一.注释 /**/ // 采用这个 二.标识符 标识符被用于语句.变量.参数.属性名.运算符和标记三.数字 javascript只有一个单一的数字模型.它在内部被表示64位的浮点数. 没有分离出整形, ...

  9. javascript语言精粹-笔记

    walkDOM function walkTheDOM(node, func) { func(node); node = node.firstChild; while (node) { walkThe ...

随机推荐

  1. 在内网中OWA第一次访问速度慢的问题

      当网络环境为内网时,有时访问OWA站点一直卡在Office Web App 那里. 这是因为SharePoint有一个证书需要联网检索 此环境为SharePoint 2013 通过下面的三个步骤 ...

  2. DevExpress免费线上公开课17日开课

    小伙伴们,前几日DevExpress 正式发布了2015的第二次重大版本v15.2.3(更新说明),对于新版本中新增的一些功能和控件,你一定会有一些疑问,比如哪些功能是值得我们关注的,哪些控件有比较重 ...

  3. jsom sharepoint 2010 循环获取多个list的item值

    <script type="text/javascript"> // <![CDATA[ var chongdianbaId; var elm = documen ...

  4. ArcGIS Engine环境下创建自定义的ArcToolbox Geoprocessing工具

    在上一篇日志中介绍了自己通过几何的方法合并断开的线要素的ArcGIS插件式的应用程序.但是后来考虑到插件式的程序的配置和使用比较繁琐,也没有比较好的错误处理机制,于是我就把之前的程序封装成一个类似于A ...

  5. <转>iOS性能优化:Instruments使用实战

    最近采用Instruments 来分析整个应用程序的性能.发现很多有意思的点,以及性能优化和一些分析性能消耗的技巧,小结如下. Instruments使用技巧 关于Instruments官方有一个很有 ...

  6. Android 利用内容提供者添加联系人的操作

    上文中<Android 获取系统的联系人>主要介绍了怎样获取系统联系人并实战了一下,本文将介绍如何添加一条联系人信息 添加联系人 1. 添加raw_contacts表,添加一条联系人的id ...

  7. IOS客户端Coding项目记录导航

    IOS客户端Coding项目记录(一) a:UITextField设置出现清除按键 b:绘画一条下划线  表格一些设置 c:可以定义表头跟底部视图(代码接上面) d:隐藏本页的导航栏 e:UIEdge ...

  8. XCode6无论如何都无法升级为XCode8为什么呀?

    因为开发微信支付需要IOS9.0版本,但是本来的XCode是6.0版本,所以最高的是8.3版本,所以要进行升级更新,但是打开更新中心发现没有更新提示,所以到AppStore里面进行下载,因为本机已经安 ...

  9. 安卓学习-- RecyclerView简单入门

    一.加入JAR包 第一感觉这个东东,好复杂,没ListView来的快,方便 在项目中加入android-support-v7-recyclerview.jar包 这个包在extras\android\ ...

  10. java中实现线程同步

    为何要使用同步? java允许多线程并发控制,当多个线程同时操作一个可共享的资源变量时(如数据的增删改查), 将会导致数据不准确,相互之间产生冲突,因此加入同步锁以避免在该线程没有完成操作之前,被其他 ...