企业🤖AI智能体构建引擎,智能编排和调试,一键部署,支持私有化部署方案 广告
## js函数定义 js使用关键字function 定义函数 ### 函数声明 >函数声明仅在调用时用到 ``` function functionName(a,b) { return a+b; } ``` >在函数表达式存储在变量后,变量也可作为一个函数使用: ``` var x = function (a, b) {return a * b}; var z = x(4, 3); ``` 上面函数为匿名函数 ### Function构造函数 >函数同样可以通过内置的 JavaScript 函数构造器(Function())定义。 ``` var myFunction = new Function("a", "b", "return a * b"); var x = myFunction(4, 3); ``` ### 函数提升(Hoisting) 1. 在之前的教程中我们已经了解了 "hoisting(提升)"。 2. 提升(Hoisting)是 JavaScript 默认将当前作用域提升到前面去的的行为。 3. 提升(Hoisting)应用在变量的声明与函数的声明。 4. 因此,函数可以在声明之前调用: ``` myFunction(5); function myFunction(y) { return y * y; } ``` >使用表达式定义函数时无法提升。 ### 自调用函数 ``` (function () { var x = "Hello!!"; // 我将调用自己 })(); ``` ### 函数是对象 * 在 JavaScript 中使用 typeof 操作符判断函数类型将返回 "function" 。 * 但是JavaScript 函数描述为一个对象更加准确。 * JavaScript 函数有 属性 和 方法。 * arguments.length 属性返回函数调用过程接收到的参数个数: ``` function myFunction(a, b) { return arguments.length; } ``` ``` function myFunction(a, b) { return a * b; } var txt = myFunction.toString(); ``` >函数定义作为对象的属性,称之为对象方法。 >函数如果用于创建新的对象,称之为对象的构造函数。