js普通函数加括号与不加括号的区别
2017-10-18 22:24
375 查看
1、JS中函数名后面的括号加与不加的区别和作用?
emo1 demo2实际上是指针,你只需要记住,函数名就是指针就可以了。
function fun(){
return 5
}
var a=fun
var b=fun()
JS中我们把以上代码加粗的部分叫做函数,函数是一种叫做function引用类型的实例,因此函数是一个对象。对象是保存在内存中的,函数名则是指向这个对象的指针。
var a = fun 表示把函数名fun这个指针拷贝一份给变量a,但是这不是指函数本身被复制了一份。
就好比,地图上上海市(对应函数对象)只有一个,但指向上海市的路标(对应指针)有很多,而且你还可以继续添加(复制)无数个指向上海市的路标,但上海市本身不会被复制。
如果函数名后面加上圆括号就表示立即调用(执行)这个函数里面的代码(花括号部分的代码)。
也就是,函数名你可以看作是一个函数整体,就是function fn(){},函数名括号就是要执行里面的内容是函数的返回值
function fun(){
alert(5);
}
var a=fun;
alert(a); //function fun(){alert(5);}
var b=fun(); //5
这里因为b=fun(),函数会跳到fun()里面,从而执行里面的内容,获得的是fun里面的返回值,如果在上面的代码上加b或者b()都会报错,因为这里的b不是function,只是一个返回值。
function fun(){
alert(5);
}
var a=fun;
alert(a);
var b=fun;
b();
这里b=fun,而fun是指整个函数,因此b是一个function类型,b()就是执行这个函数。
emo1 demo2实际上是指针,你只需要记住,函数名就是指针就可以了。
function fun(){
return 5
}
var a=fun
var b=fun()
JS中我们把以上代码加粗的部分叫做函数,函数是一种叫做function引用类型的实例,因此函数是一个对象。对象是保存在内存中的,函数名则是指向这个对象的指针。
var a = fun 表示把函数名fun这个指针拷贝一份给变量a,但是这不是指函数本身被复制了一份。
就好比,地图上上海市(对应函数对象)只有一个,但指向上海市的路标(对应指针)有很多,而且你还可以继续添加(复制)无数个指向上海市的路标,但上海市本身不会被复制。
如果函数名后面加上圆括号就表示立即调用(执行)这个函数里面的代码(花括号部分的代码)。
也就是,函数名你可以看作是一个函数整体,就是function fn(){},函数名括号就是要执行里面的内容是函数的返回值
function fun(){
alert(5);
}
var a=fun;
alert(a); //function fun(){alert(5);}
var b=fun(); //5
这里因为b=fun(),函数会跳到fun()里面,从而执行里面的内容,获得的是fun里面的返回值,如果在上面的代码上加b或者b()都会报错,因为这里的b不是function,只是一个返回值。
function fun(){
alert(5);
}
var a=fun;
alert(a);
var b=fun;
b();
这里b=fun,而fun是指整个函数,因此b是一个function类型,b()就是执行这个函数。
相关文章推荐
- js 把一个函数赋给一个变量时带括号与不带括号的区别
- Js事件绑定时,函数名加括号和不加括号有什么区别
- js中函数调用加括号和不加括号的区别
- js中普通函数和构造函数的区别
- 基于js里调用函数时,函数名带括号和不带括号的区别
- ** Javascript 普通函数和构造函数的区别 && JS----构造函数与原型prototype 区别
- js中函数之函数名带括号与不带括号的区别
- js中给函数传参函数时,函数加括号与不加括号的区别
- JS中构造函数和普通函数有什么区别
- js函数名后面加括号与不加括号的区别
- JS中函数名后面的括号加与不加的区别和作用?
- js函数加括号和不加括号的区别
- 学习笔记:js里调用函数时,函数名带括号与不带括号的区别
- JS中函数名后面的括号加与不加的区别
- JS函数中带与不带括号的区别
- js中箭头函数和普通函数this的区别
- JavaScript总结学习一:js中构造函数与普通函数的区别
- js中普通函数和构造函数的区别
- JavaScript-js中把一个函数赋给一个对象时带不带括号的区别?
- js里调用函数时,函数名带括号和不带括号的区别