js中的经典题Foo.getName

本文详细解析了JavaScript中Foo.getName方法涉及的知识点,包括this的全局指向、变量声明提升、原型链以及new运算符的优先级。通过分析不同场景下的执行情况,如Foo.getName()、getName()、Foo().getName()等,揭示了new和.运算符的优先级规则,帮助读者深入理解JavaScript的运行机制。
摘要由CSDN通过智能技术生成

Foo.getName所涉及到的知识点

先看看题目代码:

function Foo() { getName = function () { alert(1); } return this; } Foo.getName = function () { alert(2); } Foo.prototype.getName = function () { alert(3); } var getName = function () { alert(4); } function getName() { alert(5); } Foo.getName(); //2 getName(); //4 Foo().getName(); //1 getName(); //1 new Foo.getName(); //2 new Foo().getName() //3 new new Foo().getName() //3
所涉及到知识点很多,this全局指向,变量表达式与变量声明提升优先、原型链,new运算符优先级等。。

1、先看懂代码:

//创建了foo()方法,里面有全局变量并赋值为一个方法,
//return this,目前this指向全局
function Foo() 
  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值