JS中函数名后面的括号加与不加的区别和作用
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JS中函数名后面的括号加与不加的区别和作用相关的知识,希望对你有一定的参考价值。
加括号为调用该函数,返回值为函数返回值;不加括号可认为是查看函数完整信息,即查看整个函数体,返回值即整个函数体,不加括号传参相当于传入函数整体
function test()
return "test";
分别打印
test: function test() return "test"; //函数表达式
test(): test //函数执行结果 参考技术A 括号是一定要加的(标准格式)
function
hanshu1()
function
hanshu2(i)
区别:hanshu1不需要传值,hanshu2需要传值,就是这样(捕获小白一只,这个问题简单到让人难以回答,这到底是简单还是难呢???)
JavaScript--JS中函数名后面的括号加与不加的区别和作用
示例代码:
function addFunction(arg1, arg2) {
return arg1 + arg2;
}
let a = addFunction; // a 指向addFunction这个函数对象的指针
let b = addFunction(1, 2); // b = 3
- JS中我们把以上代码加粗的部分叫做函数,函数是一种叫做function引用类型的实例,因此函数是一个对象。对象是保存在内存中的,函数名则是指向这个对象的指针。
- let a = addFunction 表示把函数名addFunction这个指针拷贝一份给变量a,但是这不是指函数本身被复制了一份。就好比,地图上上海市(对应函数对象)只有一个,但指向上海市的路标(对应指针)有很多,而且你还可以继续添加(复制)无数个指向上海市的路标,但上海市本身不会被复制。
- 如果函数名后面加上圆括号就表示立即调用(执行)这个函数里面的代码(花括号部分的代码)。
小结:
使用不带圆括号的函数是访问函数的指针,而非调用函数
以上是关于JS中函数名后面的括号加与不加的区别和作用的主要内容,如果未能解决你的问题,请参考以下文章