为了账号安全,请及时绑定邮箱和手机立即绑定

js笔记三十七之函数的三种角色

标签:
JavaScript
function Fn(){    this.x = 100;
}
Fn.prototype.getX() = function(){    console.log(this.x);
}var f = new Fn;

函数本身也会有一些自己的属性:
length: 0 形参的个数
name: "Fn" 函数名
prototype 类的原型,在原型上定义的方法都是当前Fn这个类实例的公有方法
__ proto__: 把函数当做一个普通对象,执行Function这个类的原型

函数在整个js中是最复杂也是最重要的知识

  1. 一个函数存在了多面性:

    1. "普通函数": 它本身就是一个普通的函数,执行的时候形成私有的作用域(闭包),形参赋值,预解释,代码执行,执行完成后栈内存销毁/不销毁

    2. "": 它有自己的实例,也有一个叫做prototype属性是自己的原型,它的实例都可以指向自己的原型

    3. "普通对象": 和 var obj = {}中的obj一样,就是一个普通对象,它作为对象可以有一些自己的私有属性,也可以通过__ proto__找到Function.prototype

三者之间互不冲突,没有任何关系

function Fn(){    var num = 500;    this.x = 100;
};
Fn.prototype.getX() = function(){    console.log(this.x);
};
Fn.aaa = 1000;var f = new Fn; // Fn中的this是ff.num  // -> undefinedf.aaa  // -> undefined var res = Fn(); // Fn中的this是windowres // undefinedFn.aaa // 1000



作者:uplyw
链接:https://www.jianshu.com/p/e391c71d74c6


点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消