javascript定义函数的类型有哪些
这篇文章主要为大家展示了“javascript定义函数的类型有哪些”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“javascript定义函数的类型有哪些”这篇文章吧。
在JavaScript中定义函数的几种类型:1、利用function关键字通过声明或表达式定义函数,语法为“function functionName(parameters){执行的代码}”;2、利用函数构造器Function()构造函数。
本教程操作环境:windows10系统、javascript1.8.5版、Dell G3电脑。
javascript定义函数的几种类型是什么
JavaScript 使用关键字 function 定义函数。
函数可以通过声明定义,也可以是一个表达式。
函数声明
在之前的教程中,你已经了解了函数声明的语法 :
function functionName(parameters) { 执行的代码 }
函数声明后不会立即执行,会在我们需要的时候调用到。
函数构造器
函数构造器用于创建一个函数对象,在JavaScript中实际上每一个函数都是一个函数对象。
函数构造器的语法:
new Function ([arg1[, arg2[, ...argN]],] functionBody)
arg1, arg2, ... argN 被用于作为函数正常参数名的变量名字,这些变量名必须是符合JavaScript变量标识规范的表示单个变量的字符串或者以逗号分隔的表示多个变量的字符串,比如"x", "theValue", or "a,b"。
functionBody 包含函数定义的JavaScript语句的字符串。
描述
1.函数对象在函数构造器被解析成为函数的时候被创建。但是这样会比以函数声明、函数表达式等方式低效,因为这些函数时通过代码直接解析的。
2.传递给函数构造器的字符串参数都会被当作函数构造器生成函数的变量参数名字,以他们出现的顺序作为生成的函数的参数的顺序。
3.以函数的方式调用函数构造器(不管用不用new关键词修饰)效果一样。
例子
// Example can be run directly in your JavaScript console // Create a function that takes two arguments and returns the sum of those arguments var adder = new Function('a', 'b', 'return a + b'); // Call the function adder(2, 6); // > 8
参数a和b是可以在函数体内使用的正常的参数名字。
生成的函数为:
function (a,b){undefined return a+b; }
关于json解析的一种方式:var json = (new Function("return " + str))();
原理一样,
生成的函数为:
function toJson(str){undefined return str; } var str="{'a':1,'b':'abc'}"; toJson(str);
即:function(){return {'a':1,'b':'abc'}}
函数构造器和函数声明的区别:
用函数构造器创建的函数不会在上下文中创建闭包,它们总是被创建在全局作用域中,当执行被创建的函数时,它们只能使用自己的局部变量或者全局变量,这和eval是不同的。
以上是“javascript定义函数的类型有哪些”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注蜗牛博客行业资讯频道!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:niceseo99@gmail.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。
评论