js:深入函数的定义

js:深入函数的定义,第1张

函数定义方式: 1.function fun1(){alert("fun1");}  //函数就是一个非常特殊的对象,是一个Function的实例,其实在内存中存储的 *** 作是通过一个键值对来存储的。 2.由于函数是一个对象,所以可以通过如下方式定义 var fun2 = fun1;  //通过函数拷贝给fun2完成赋值,但fun1、fun2这两个引用并没有指向同一个对象(虽然他们指向的对象的内容是一样的)。 fun1 = function(){alert("fun111");} //函数虽然是一个对象,但是却和对象有一些区别,对象是通过引用的指向来完成对象的赋值的, 而函数却是通过对象的拷贝来完成的。所以fun1即使变了,也不会影响fun2。 fun2();  //fun1 fun1();  //fun111

//对于对象而言,是通过引用的指向来完成赋值的,此时修改o1或者o2会导致另一方的指向随之改变。 var o1 = new Object(); var o2 = o1;  //o1、o2指向同一块空间 o2.name = "octopus"; alert(o1.name); //octopus //

-------------------------------------------------------------------------------------- 1). function sum(num1,num2){return num1+num2;}    //相当于:var sum = function(num1,num2){return num1+num2;} 2). function sum(num1){return num1;}              //相当于:var sum = function(num1){return num1} alert(sum(1));  //1 alert(sum(1,1));//1,不是2 /*此时sum所指向的空间已经从有两个参数的函数变化到只有num1的函数中,   在调用的时候就只会调用只有num1的函数,   特别指出:函数的参数和调用没有关系,如果函数只有一个参数,但是却传入了两个参数,仅仅只会匹配一个   所以在js中函数不存在重载。*/

3.var fn = new Function{"num1","num2","alert(‘fun:‘+(num1+num2));"};   //等价于:function fn(num1,num2){alert(num1+num2);}

//函数是对象,不存在重载,只存在覆盖,后面的定义会覆盖前面的定义。

 

原创文章如转载,请注明出处”“本文首发于csdn网站:http://blog.csdn.net/magneto7/article/details/24584213”             

js:深入函数的定义,布布扣,bubuko.com

js:深入函数的定义

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/zaji/1006909.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-22
下一篇 2022-05-22

发表评论

登录后才能评论

评论列表(0条)

保存