Function类型

一、概念

Function(函数)类型实际上是对象。每个函数都是 Function 类型的 实例,而且都与其他引用类型一样具有属性和方法。由于函数是对象,因此函数名实际上也 是一个指向函数对象的指针


二、作为值的函数

ECMAScript 中的函数名本身就是变量,所以函数也可以作为值来使用。也就是说,不 仅可以像传递参数一样把一个函数传递给另一个函数,而且可以将一个函数作为另一个函数 的结果返回。

function box(sumFunction, num){
     return sumFunction(num);
}
function sum(num) {
     returnnum+10;
}
varresult=box(sum,10);

三、函数内部属性

  • arguments
function box(num){
   if(num<=1){
         return 1; 
      }
  else{
         return  num*arguments.callee(num-1);//使用 callee 来执行自身 等同于returnnum*box(num-1);
     }
 }
  • this
window.color='红色的'; //全局的 或者写成var color = '红色的'
alert(this.color); //打印全局的 color

var box={
   color:'蓝色的', //局部的 color 
   sayColor :function(){ 
           alert(this.color); //此时的 this 只能 box 里的 color 
                       } 
        };

box.sayColor(); //打印局部的 color 
alert(this.color); //还是全局的

四、函数属性和方法

  • length 属性表示函数希望接收的命名参数的个数
  functionbox(name,age){
         alert(name+age); 
   }
   alert(box.length);
  • prototype 属性 (原型)
    为一个特定类声明通用的变量或者函数。

    function Test(){
    
    }
    alert(Test.prototype); // 输出 "Object"
    
  • 用prototype给对象 添加属性

 function Fish(name, color){
  this.name=name;
  this.color=color;
 }
Fish.prototype.livesIn="water";
Fish.prototype.price=20;
  • 用prototype给对象添加函数
    function Employee(name, salary)
    {
      this.name=name;               
      this.salary=salary;
    }

   Employee.prototype.getSalary=function getSalaryFunction()
    {
     return this.salary;
    }
    Employee.prototype.addSalary=function addSalaryFunction(addition)
    {
     this.salary=this.salary+addition;
    }
  • 每个函数都 包含这两个非继承而来的方法。apply()和 call()

var color='红色的'; //或者 window.color='红色的';
var box={
color:'蓝色的'
};
function sayColor(){
alert(this.color);
}
sayColor(); //作用域在 window
sayColor.call(this); //作用域在 window
sayColor.call(window); //作用域在 window
sayColor.call(box); //作用域在 box,对象冒充

注:

使用 call()或者 apply()来扩充作用域的最大好处,
就是对象不需要与方法发生任何耦合 关系(耦合,
就是互相关联的意思,
扩展和维护会发生连锁反应)。
也就是说,
box 对象和 sayColor()方法之间不会有多余的关联操作,
比如 box.sayColor=sayColor;



最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 工厂模式类似于现实生活中的工厂可以产生大量相似的商品,去做同样的事情,实现同样的效果;这时候需要使用工厂模式。简单...
    舟渔行舟阅读 12,385评论 2 17
  • Function类型 每个函数都是Function类型的实例,因此函数名实际上也是一个指向函数对象的指针 一、函数...
    McRay阅读 1,001评论 0 1
  • 单例模式 适用场景:可能会在场景中使用到对象,但只有一个实例,加载时并不主动创建,需要时才创建 最常见的单例模式,...
    Obeing阅读 6,382评论 1 10
  • Function类型 函数实际上是对象,每个函数都是Function类型的实例,而且都与其他引用类型一样具有属性和...
    胖胖冰阅读 4,542评论 0 8
  • 一。不带圆括号的函数名访问的是函数指针,而非调用函数 //不带圆括号的函数名访问的是函数指针,而非调用函数 fun...
    PomeloTerminal阅读 2,675评论 0 3