关于js函数解释(包括内嵌,对象等)
常用写法:
function add(a,b) { return a + b; } alert(add(1,2)); // 结果 3
当我们这么定义函数的时候,函数内容会被编译(但不会立即执行,除非我们去调用它)。而且,也许你不知道,当这个函数创建的时候有一个同名的对象也被创建。就我们的例子来说,我们现在有一个对象叫做“add”(要更深入了解,看底下函数:对象节。)
匿名函数:
我们也可以通过指派一个变量名给匿名函数的方式来定义它。
var add = function(a,b) { return a + b; } alert(add(1,2)); // 结果 3
这个代码和前一个例子做了同样的事情。也许语法看起来比较奇怪,但它应该更能让你感觉到函数是一个对象,而且我们只是为这个对象指派了一个名称。可以把它看做和 var myVar=[1,2,3]一样的语句。以这种方式声明的函数内容也一样会被编译。
当我们指派一个这样的函数的时候,我们并不一定要求必须是匿名函数。在这里,我作了和以上一样的事情,但我加了函数名“theAdd”,而且我可以通过调用函数名或者是那个变量来引用函数。
var add = function theAdd(a,b) { return a + b; } alert(add(1,2)); // 结果 3 alert(theAdd(1,2)); // 结果也是 3
使用这种方式来定义函数在面向对象编程中是很有用的,因为我们能像底下这样使一个函数成为一个对象的属性。
var myObject = new Object(); myObject.add = function(a,b){return a+b}; // myObject 现在有一个叫做“add”的属性(或方法)” // 而且我能够象狼蚁网站SEO优化这样使用它 myObject.add(1, 2);
函数:对象
函数是javascript中的一种特殊形式的对象。它是第一个[b〕类数据类型(classdata type)。这意味着我们能够给它增加属性。这里有一些需要注意的有趣观点
对象的创建
就像刚才提及的,当我们定义一个函数时,javascript实际上在后台为你创建了一个对象。这个对象的名称就是函数名本身。这个对象的类型是function。在狼蚁网站SEO优化的例子,我们也许不会意识到这一点,但我们实际上已经创建了一个对象:它叫做Ball。
function ball() // 也许看起来有点奇怪,但是这个声明 { // 创建了一个叫做Ball的对象 i = 1; } alert(typeof ball); // 结果 "function"
我们甚至能将这个对象的内容打印出来而且它会输出这个函数的实际代码
alert(ball); //结果为: //function ball() //{ // i = 1; /