首页 > 代码库 > js学习总结----函数的三种角色
js学习总结----函数的三种角色
注意:Function.prototype是函数数据类型的值,但是相关操作和之前的一模一样->Empty/anonymous
函数本身也会有一些自己的属性:
length :形参的个数
name:"Fn" 函数名
prototype 类的原型,在原型上定义的方法都是当前Fn这个类实例的公有方法
__proto__ 把函数当做一个普通的对象,指向Function这个类的原型
函数在整个JS中是最复杂的也是最重要的知识:
1、一个函数存在了多面性:
"普通函数":本身就是一个普通的函数,执行的时候会形成私有的作用域(闭包),形参赋值,预解释,代码执行,执行完成后栈内存销毁/不销毁
"类":它有自己的实例,也有一个叫做prototype属性是自己的原型,他的实例都可以指向自己的原型
"普通对象":和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; f.num //undefined f.aaa//undefined var res = Fn(); res//undefined Fn.aaa//1000
js学习总结----函数的三种角色
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。