JavaScript常见错误:函数名 is not a function

时间:2020-04-13 11:46:31 来源:网络

【摘要】 报错是编程中最常遇到的问题。那么你知道关于JavaScript常见错误:函数名 is not a function的相关信息吗?考必过为大家整理了JavaScript常见错误:函数名 is not a function,一起来看看吧!

js中常见的错误,例如Uncaught TypeError: x is not a function

其原因除了函数本身有错之外,还有一种很奇怪的情况:函数本身没有错,但是运行时就是不能正常运行。这种情况与javascript的特性有关:变量与函数声明前置的优先级。

首先看代码:

console.log(x)

console.log(x());

var x=1;

function x(){

console.log(5);

}

console.log(x)

console.log(x());//此时x变成了一个变量

输出结果:

function x(){

console.log(5);

}

5

1

Uncaught TypeError: x is not a function

第一次输出x时,输出的是x函数,但是x变量的声明在x函数之前,就算要输出也应该输出的是undefined,为什么会输出函数?

js上下文中无非就是变量、函数、函数参数,那么js解释器在对其上下文进行解释执行时分为三个阶段来进行:声明阶段、初始化阶段、执行阶段。

针对js上下文,首先会进行声明阶段,声明阶段中的特点是声明前置;声明又会包括变量声明前置和函数声明前置,鉴于以上代码的输出结果,我们可以得出函数声明前置优先于变量声明前置的特点,并且如果变量名和函数名冲突会忽略变量的声明,因此声明过得变量名或函数名不会重复声明,这样也可以很好地解释为什么第一次输出的是函数而不是undefined。根据js的这些特点我们可以将以上代码解析成如下:

//声明阶段

function x(){//函数声明

console.log(5);

}

var x;//变量声明,因为x已经声明过了,此处不进行声明(忽略)

//执行阶段

console.log(x);

console.log(x());

x=1;

console.log(x);

console.log(x());

如上代码所述,js将变量和函数的声明前置,然后再执行代码。

第二次输出时,因为声明阶段已经声明过名为x的函数,所以在执行阶段中调用x函数,会执行函数体中的内容。

第三次输出时,输出1,因为x被赋值为1.

第四次输出时,因为x此时是一个变量而不是一个函数,所以js无法解释“变量()”这样的格式,就会提示“x is not a function”。

js中声明过得变量名或函数名不会重复声明,如果js代码中有同名的函数或同名的变量时,程序如何运行,如下代码:

console.log(x)

console.log(x());

var x=1;

var x=100;

function x(){

console.log(5);

}

function x(){

console.log(500);

}

console.log(x)

console.log(x());//此时x变

根据js解析代码的特点,将代码解析成如下:

//声明阶段

function x(){//函数声明

//console.log(5);此句会被下句代码覆盖

console.log(3);

}

var x;//变量声明,因为x已经声明过了,此处不进行声明(忽略)

//执行阶段

console.log(x);

console.log(x());

x=1;

x=100;//x的值被覆盖

console.log(x);

console.log(x());

所以输出的结果就是:

function x(){

console.log(3);

}

3

100

Uncaught TypeError: x is not a function

针对变量名同名或函数名同名的情况,我们又可以得出一个特点:如果声明了同名的函数其定义会被后者覆盖,声明了同名的变量其值也会被后者覆盖

————————————————

本文为CSDN博主「JEE__hh」的原创文章,转载请附上原文出处链接及本声明。

原文链接:https://blog.csdn.net/weixin_40345099/java/article/details/82912474

以上就是关于JavaScript常见错误:函数名 is not a function的详细内容,希望本篇文章对大家有所帮助。虽然考试受到影响,但是考生们不能因此懈怠。我们将根据疫情防控的进展情况,动态更新并通知考试的报名和考试安排,更多资讯关注考必过网站。

上一篇      下一篇
前端相关推荐 更多>>
JavaScript常见问题:TypeError: ‘undefined' is not an object JavaScript常见问题:TypeError: null is not an object JavaScript常见问题:TypeError: ‘undefined' is not a function JavaScript常见问题:ReferenceError: event is not defined JS常见问题:xx is not defined at HTMLAnchorElement.onclick 【Web前端基础知识】关于Js中this的指向 centos 7 Docker容器启动报WARNING: IPv4 forwarding Hibernate 与 Mybatis 如何共存?打破你的认知!
前端热点专题 更多>>
热点问答
国家公务员考试年龄限制是多少 公务员国考和省考考试内容有什么区别 函授大专学历能不能考公务员 国家公务员考试考点能自己选择吗 新闻学专业能报考2022年公务员考试吗 什么是联合培养研究生 什么是破格录取研究生 什么人不适合读研 研究生报名户口所在地填什么 研究生结业和毕业有什么区别
网站首页 网站地图 返回顶部
考必过移动版 https://m.kaobiguo.net