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. Node创建应用

    github地址:https://github.com/lily1010/Node_learn/tree/master/test 一 使用node的意义 使用 Node.js 时,我们不仅仅 在实现一 ...

  2. js实现标准无缝滚动

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  3. 使用 jQuery Mockjax 插件模拟 Ajax 请求

    在实际的开发过程中,前端后台协商好了统一的接口,就各自开始自己的任务了.这时候我有这么一个 Ajax 请求需要从后台获取数据: $.ajax({ url: '/products/' }).done(f ...

  4. SharePoint 2013 重命名网站集名称(SharePoint 2013 rename site collection)

    最近使用SharePoint中,遇到一个需要重命名网站集的需求,主要是网站用数据库备份/还原的方式,想要改网站集的地址,然后搜了一下PowerShell: $site = Get-SPSite -Id ...

  5. Udp通讯(零基础)

    前面学习了Tcp通讯之后听老师同学们讲到Udp也可以通讯,实现还要跟简单,没有繁琐的连接,所以最近学习了一下,记录下来以便忘记,同时也发表出来与大家相互学习,下面是我自己写的一个聊天例子,实现了群聊私 ...

  6. [Android]使用AdapterTypeRender对不同类型的item数据到UI的渲染

    以下内容为原创,转载请注明: 来自天天博客:http://www.cnblogs.com/tiantianbyconan/p/3992843.html 本文讲的工具均放在AndroidBucket开源 ...

  7. Ida动态修改android程序的内存数据和寄存器数值,绕过so文件的判断语句

    我们继续分析自毁程序密码这个app,我们发现该程序会用fopen ()打开/proc/[pid]/status这个文件,随后会用fgets()和strstr()来获取,于是我们在strstr()处下个 ...

  8. Several ports (8005, 8080, 8009) required by Tomcat v7.0 Server at localhost are already in use.解决办法

    Several ports (8005, 8080, 8009) required by Tomcat v7.0 Server at localhost are already in use. The ...

  9. iOS 被拒问题及原因 - IDFA问题

    IDFA问题 iOS APP上线被拒绝的问题解决(AdSupport),百度统计,友盟统计,讯飞语音等   苹果反馈信息如下: .... To process your delivery, the f ...

  10. MPlayerX——MAC OS 最好用的播放器

    MPlayerX真是一个不错的软件,它真的可以称得上在MAC OS里最好用的播放器,它功能强大,可以播放你所知道的任何格式的视频和音频文件.他的选项非常丰富,可以自定义设置的东西很多,但又不失简洁的风 ...