js中函数的属性和方法

在js中,函数也是对象,所以也有属性和方法

属性
  1. caller 指向被调用的函数
function outer() {
	innert()
}

function inner(){
	alert(inner.caller); 
}

outer(); //outer, 因为是outer调用了inner

//解决依赖
function innert() {
	alert(arguments.callee.caller); argument.callee指向所在函数的名字
}
  1. this 指向当前函数执行环境对象
  2. length 指向函数希望参数的长度
function sayName(name) {
}
alert(sayName.length); //1
  1. prototype 指向函数的原型对象
函数
  1. apply
  2. call
    都是扩充函数的作用域,区别是传递参数的方式不同
window.color = "red";
var o = {color: "blue"};

function syaColor() {
	return this.color;
}

syaColor(this); //red
syaColor(window); //red
syaColor(o); // blue

3.bind 还有一个扩展作用域的方法 , 不同的是返回一个绑定作用域后的函数

window.color = "red";
var o = {color:"blue"};
function syaColor() {
	return this.color;
}

var bindFunction = syaColor.bind(o);
bindFunction(); //blue
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值