


The editor brings you a piece of basic teaching content about javascript, about the training and understanding of the Function function in javascript, if you are interested in javascript Let’s study together with our classmates.
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 the Function function and explain its practical usage.
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 defaults the first N parameters 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 from the above statement You can see that the add variable points to an instance of Function type, but this naming method is very cumbersome and is equivalent to:
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, so the first edition advocates using the second method to define functions. There is a separate article about function declaration in advance
But the first definition method makes it very intuitive to see that add is a 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 returned from the function.
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 points to the reference of null after removing the reference of the function object. Therefore It does not affect the add2 and add3 functions at all.
So the function can be passed in as a parameter of other functions.
So the function can be used as the return value of the functionReturn.
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. In the end, it still represents the same function.
Since a function is an instance of an object, it should have properties and methods. Therefore, functions in JavaScript have properties and methods.
The four more important properties are arguments, this, length, and prototype
arguments represents the parameter array of the current function. This attribute is very special. It also has an attribute called callee. The
arguments.callee attribute stores a pointer that points to the argument attribute that owns it. The function entity (which is equivalent to the function name)
this attribute is the current environment, similar to this in C#, indicating the current context
The length attribute indicates the maximum number of parameters received by the current function
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: overwriting with the same name, arguments objects, default return values, etc.
function ShowName(name) { alert(name); }
##Anonymous function: Introduction to anonymous functions Features: variable anonymous functions, nameless anonymous functions.
//变量匿名函数,左侧可以为变量、事件等 var anonymousNormal = function (p1, p2) { alert(p1+p2); } anonymousNormal(3,6);//输出9
## Closure 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:
Explanation of passing by value of js function parameters
About the understanding of this in js functionsIn-depth understanding of the parameters of JS functions Use of (arguments)The above is the detailed content of JavaScript Function Function Understanding and Practical Combination_Basic Knowledge. 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执行机制等等相关内容,下面一起来看一下,希望对大家有帮助。

本篇文章整理了20+Vue面试题分享给大家,同时附上答案解析。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。


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

MantisBT
Mantis is an easy-to-deploy web-based defect tracking tool designed to aid in product defect tracking. It requires PHP, MySQL and a web server. Check out our demo and hosting services.

mPDF
mPDF is a PHP library that can generate PDF files from UTF-8 encoded HTML. The original author, Ian Back, wrote mPDF to output PDF files "on the fly" from his website and handle different languages. It is slower than original scripts like HTML2FPDF and produces larger files when using Unicode fonts, but supports CSS styles etc. and has a lot of enhancements. Supports almost all languages, including RTL (Arabic and Hebrew) and CJK (Chinese, Japanese and Korean). Supports nested block-level elements (such as P, DIV),

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

Safe Exam Browser
Safe Exam Browser is a secure browser environment for taking online exams securely. This software turns any computer into a secure workstation. It controls access to any utility and prevents students from using unauthorized resources.
