Home > Web Front-end > JS Tutorial > What are the types of functions defined in javascript

What are the types of functions defined in javascript

WBOY
Release: 2022-03-10 14:57:06
Original
2601 people have browsed it

Several types of functions are defined in JavaScript: 1. Use the function keyword to define functions through declarations or expressions. The syntax is "function functionName(parameters){executed code}"; 2. Use function constructs Function() constructor.

What are the types of functions defined in javascript

The operating environment of this tutorial: Windows 10 system, JavaScript version 1.8.5, Dell G3 computer.

What are the types of functions defined in JavaScript

JavaScript uses the keyword function to define functions.

A function can be defined through a declaration or an expression.

Function declaration

In the previous tutorial, you have already understood the syntax of function declaration:

function functionName(parameters) {
  执行的代码
}
Copy after login

The function will not be executed immediately after it is declared, but will be executed when we need it Called to.

Function constructor

The function constructor is used to create a function object. In JavaScript, actually every function is a function object.

The syntax of function constructor:

new Function ([arg1[, arg2[, ...argN]],] functionBody)
Copy after login

arg1, arg2, ... argN are used as variable names as normal parameter names of functions. These variable names must comply with the JavaScript variable identification specification. A string representing a single variable or a comma-separated string representing multiple variables, such as "x", "theValue", or "a,b".

functionBody A string containing the JavaScript statement that defines the function.

Description

1. The function object is created when the function constructor is parsed into a function. However, this will be less efficient than using function declarations, function expressions, etc., because these functions are directly parsed through the code.

2. The string parameters passed to the function constructor will be used as the variable parameter names of the function generated by the function constructor, and the order in which they appear will be used as the order of the parameters of the generated function.

3. Calling the function constructor as a function (whether modified with the new keyword or not) has the same effect.

Example

// 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
Copy after login

Parameters a and b are normal parameter names that can be used in the function body.

The generated function is:

function (a,b){undefined
  return a+b;
}
Copy after login

A way to parse json: var json = (new Function("return " str))();

The principle is the same ,

The generated function is:

function toJson(str){undefined
   return str;
}
var str="{'a':1,'b':'abc'}";
toJson(str);
Copy after login

That is: function(){return {'a':1,'b':'abc'}}

Function construction The difference between constructor and function declaration:

Functions created with function constructors do not create closures in the context. They are always created in the global scope. When the created function is executed, they only You can use your own local variables or global variables, which is different from eval.

Related recommendations: javascript learning tutorial

The above is the detailed content of What are the types of functions defined in javascript. For more information, please follow other related articles on the PHP Chinese website!

Related labels:
source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template