JavaScript Function类型

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

var caibaojian = function(num1,num2){ //使用变量初始化

return num1+num2;

}

alert(caibaojian(1,2));

function box(num1, num2){//普通函数声明

retrun num1+num2;

}

var box = new Function('num1','b', 'return num1+b');

//使用new的构造函数声明,函数是对象,函数名是指针。

函数调用自身,使用arguments.callee,实现递归

window是一个对象,而且是JS里面最大的对象,是最外围的对象

alert(typeof window); window是对象,类型是对象,window表示全局

alert(this); [object window] this目前表示的是window,因为在window的范围下

alert(typeof this)和window一模一样,所以this就是window

function sum(num){

if(num <=1){

return 1;

}else{

return num*arguments.callee(num - 1);

}}

alert(sum(4)); 4!

函数属性和方法

box.length

prototype属性

两个方法,apply()和call(),每个函数都包含这两种非继承而来的方法

function box(num1, num2){

return num1+num2;}

function sum(num1,num2){

return box.apply(this, [num1, num2]);

function sum2(num1, num2){

return box.apply(this,arguments);}

function sum3(num1, num2){

return box.call(this,num1,num2);}

var color = '红色的'; var box = { color=’蓝色的';};

function sayColor(){

alert(this.color);}

sayColor.call(box); //蓝色的

关注我

我的微信公众号:前端开发博客,在后台回复以下关键字可以获取资源。

  • 回复「小抄」,领取Vue、JavaScript 和 WebComponent 小抄 PDF
  • 回复「Vue脑图」获取 Vue 相关脑图
  • 回复「思维图」获取 JavaScript 相关思维图
  • 回复「简历」获取简历制作建议
  • 回复「简历模板」获取精选的简历模板
  • 回复「加群」进入500人前端精英群
  • 回复「电子书」下载我整理的大量前端资源,含面试、Vue实战项目、CSS和JavaScript电子书等。
  • 回复「知识点」下载高清JavaScript知识点图谱

每日分享有用的前端开发知识,加我微信:caibaojian89 交流