javascript函数包含的东东

来源:互联网 发布:数据库建立流程图 编辑:程序博客网 时间:2024/05/17 02:12


  1. 函数对象
  2. 函数字面量
    类似这样的 
    var add = function(a,b){      return a+b;}



  3. 调用:
    函数调用时,接收2个附加的参数:this和arguments 。this 在面向对象编程中非常重要, 它的取值决于调用模式。
    4中调用模式:方法调用模式,函数调用模式,构造器调用模式,apply调用模式
    arguments:拥有length属性,可以通过arguments[i]访问,但是它并不是数组,没有数组的其它功能
  4. 参数:
  5. 返回
  6. 异常:javascript中也具有exception对象 看代码
    var add = function(a,b){    if(typeof a!=='number' || typeof b !=='number'){       throw {           name:'TypeError',           message:'add needs numbers'       };     }     return a+b;}var try_it = function(){      try{            add('seven');      }catch(e){         document.writeln(e.name+' ; '+e.message);     }}

  7. 给类型增加方法:
    javascript允许通过prototype 给语言的基本类型增加方法,给函数Function,数组Array,字符串String,数字Number,布尔值,正则表达式
    通过给基本类型增加方法,我们可以大大提高语言的表现力。因为JS原型继承的动态本质,新的方法立刻被赋予到所有的值(对象实例)上,哪怕值(对象实例)
    是在方法被创建之前就创建好了。
  8. 递归
  9. 作用域
    在编程语言中,作用域控制着变量与参数的可见性及生命周期。且提供了自动的内存管理。
    JS缺少块级作用域,所以最好在函数体的顶部声明函数中可能要用到的所有变量。
  10. 闭包:该函数可以访问它被创建时所处的上下文环境。
    //产生一个序列号var serial_maker = function(){      var prefix = '';      var seq = 0;      return {            set_prefix: function(p){                  prefix = String(p);            },            set_seq:function(s){                  seq = s;            },            gensym:function(){               var result = prefix+seq;               seq+=1;               return result ;           }               };}//var seqer = serial_maker();seqer.set_prefix('q');seqer.set_seq(1000);var unique = seqer.gensym(); //unique is "q1000"


  11. 模块:可以使用函数和闭包来构建模块。模块是一个提供接口却隐藏状态与实现的函数或对象。通过使用函数去产生模块,我们几乎可以完全摒弃全局变量的使用,
    从而缓解这个JS的最为糟糕的特性之一所带来的影响。
  12. 级联:通过给方法返回this 来启用级联
  13. 套用及记忆可以通过闭包来实现


0 0
原创粉丝点击