Function function is the foundation of JavaScript and a tipping point for realizing functions. Through example analysis, we will give you a deeper understanding of Function functions and explain their practical usage. This article mainly brings you a piece of basic teaching content about JavaScript, and about the training and understanding of Function functions. Let’s learn together.
Function is indeed an object. And any function we define is actually an instance of the Function object, which can also be understood as pointing to an instance of the Function object.
Since it is an instance of the object instance, it must point to a reference of the Function type. Since it points to a memory address of a reference type, you can also simply understand the function we defined as a variable, which points to an address of a reference type. This address Points to an instance of the Function object.
Since the function we defined is actually a variable, this function instance address can point to multiple variables at the same time.
Look at the following code:
var add = new Function("n", "m", "return n + m");
The above is the standard function definition, which calls the constructor of the Function object. This constructor The first N parameters default to the parameters of the new function, until the last parameter is considered to be the function body of the new function.
It is very intuitive to see from the above statement that the add variable points to a Function type Example, but this naming method is very cumbersome, equivalent to:
(1) Function expression
##
var add=function(n,m){ return n+m; }(2) Function declaration
function add(n,m){ return n+m; }Because the declaration in the JavaScript language is advanced, the first edition advocates using the second method to define functions. Regarding function declarations, a separate article is opened in advanceBut The first definition method makes it very intuitive to see that add is a variable pointing to a function instance. Since it is a variable, it can be assigned to other variables, passed as a parameter in the function, or passed from The function returns.So var add2=add3=add; Now all three variables point to the reference of this instance, now add=null; In the future, the two functions add2 and add3 can be used without being affected, because add After removing the reference to the function object, it points to a null reference. Therefore, the two functions add2 and add3 are not affected at all.So the function can be passed in as a parameter of other functions.So the function can Returned as the return value of the function. Because the function name is just a variable pointing to the function instance, there will be no overloading of functions in JavaScript, because the same variable points to the same reference address. The last representation is still The same function.Since a function is an instance of an object, it should have attributes and methods. Therefore, functions in JavaScript have attributes and methods.Four more important attributes arguments , this , length , prototypearguments represents the parameter array of the current function. This property is very special. It also has a property called callee. The arguments.callee property stores a pointer. , the pointer points to the function entity with this arguments attribute (which is equivalent to the function name) this attribute is the current environment, similar to this in C#, indicating the current context length attribute representation The current function receives the maximum number of parameters prototype represents the prototype of the function, which means that the methods of the object instance are completely saved. In other words, all the methods on the prototype are inherited. For example, toString() valueOf () etc.
Next, let’s take a look at the types of function functions
Ordinary functions: Introducing the characteristics of ordinary functions: same-name coverage, arguments objects, default return values wait.function ShowName(name) { alert(name); }Anonymous functions: Introducing the characteristics of anonymous functions: variable anonymous functions, nameless anonymous functions.
//变量匿名函数,左侧可以为变量、事件等 var anonymousNormal = function (p1, p2) { alert(p1+p2); } anonymousNormal(3,6);//输出9Closure function: Introduce the characteristics of closure function.
function funA() { var i = 0; function funB() { //闭包函数funB i++; alert(i) } return funB; } var allShowA = funA(); //全局变量引用:累加输出1,2,3,4等 function partShowA() { var showa = funA();//局部变量引用:只输出1 showa(); }Related recommendations:
Detailed introduction of the register_shutdown_function function
javascript Function function understanding and Practical combat_Basic knowledge
Detailed explanation of how to use the function bind method in Javascript
The above is the detailed content of JavaScript Function function understanding and practice. For more information, please follow other related articles on the PHP Chinese website!

去掉重复并排序的方法:1、使用“Array.from(new Set(arr))”或者“[…new Set(arr)]”语句,去掉数组中的重复元素,返回去重后的新数组;2、利用sort()对去重数组进行排序,语法“去重数组.sort()”。

本篇文章给大家带来了关于JavaScript的相关知识,其中主要介绍了关于Symbol类型、隐藏属性及全局注册表的相关问题,包括了Symbol类型的描述、Symbol不会隐式转字符串等问题,下面一起来看一下,希望对大家有帮助。

怎么制作文字轮播与图片轮播?大家第一想到的是不是利用js,其实利用纯CSS也能实现文字轮播与图片轮播,下面来看看实现方法,希望对大家有所帮助!

本篇文章给大家带来了关于JavaScript的相关知识,其中主要介绍了关于对象的构造函数和new操作符,构造函数是所有对象的成员方法中,最早被调用的那个,下面一起来看一下吧,希望对大家有帮助。

本篇文章给大家带来了关于JavaScript的相关知识,其中主要介绍了关于面向对象的相关问题,包括了属性描述符、数据描述符、存取描述符等等内容,下面一起来看一下,希望对大家有帮助。

方法:1、利用“点击元素对象.unbind("click");”方法,该方法可以移除被选元素的事件处理程序;2、利用“点击元素对象.off("click");”方法,该方法可以移除通过on()方法添加的事件处理程序。

本篇文章给大家带来了关于JavaScript的相关知识,其中主要介绍了关于BOM操作的相关问题,包括了window对象的常见事件、JavaScript执行机制等等相关内容,下面一起来看一下,希望对大家有帮助。

foreach不是es6的方法。foreach是es3中一个遍历数组的方法,可以调用数组的每个元素,并将元素传给回调函数进行处理,语法“array.forEach(function(当前元素,索引,数组){...})”;该方法不处理空数组。


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

SublimeText3 English version
Recommended: Win version, supports code prompts!

SAP NetWeaver Server Adapter for Eclipse
Integrate Eclipse with SAP NetWeaver application server.

WebStorm Mac version
Useful JavaScript development tools

SublimeText3 Linux new version
SublimeText3 Linux latest version

MinGW - Minimalist GNU for Windows
This project is in the process of being migrated to osdn.net/projects/mingw, you can continue to follow us there. MinGW: A native Windows port of the GNU Compiler Collection (GCC), freely distributable import libraries and header files for building native Windows applications; includes extensions to the MSVC runtime to support C99 functionality. All MinGW software can run on 64-bit Windows platforms.
