


1. Function calling method
1. As a function, it is a direct and easy-to-understand method (i.e. function calling mode).
2. As a method, the method is connected to the object and called by the object. This form is object-oriented programming.
3. As a constructor, a new object is created during the construction process.
4. Via the apply or call method of the function.
This article mainly brings you a brief discussion of the different ways of function calling and the direction of this. The editor thinks it is quite good, so I will share it with you now and give it as a reference for everyone. Let’s follow the editor to take a look, I hope it can help everyone.
2. Function parameters
1. Incoming parameters
(1) There are more incoming variables than function definition variables.
(2) There are more variables passed in when defining variables in the function, and the extra variables are undefined
2. When the function is called, the two parameters argument and this are passed in implicitly (i.e. argument and this are quietly passed into the function and act in the scope of the function).
(1)argument: The set of variables passed into the function when the function is called (with the argument.length attribute)
eg: argument[0] refers to the first parameter passed into the function
(2) this is associated with an object.
Depending on the calling method, the point of this is also different. Therefore this is the invocation context.
3. Pointing to this
1. Function calling mode (this->window)
This function does not belong to the attributes of any object.
function fn1(){ //some code } fn1(); 或着: var fn2=function(){ //some code } fn2(); 使用这种方式调用函数,函数的上下文是全局上下文(global context即window)。this->window。
2. Method calling mode (this->The object to which the method belongs)
This function is a property of an object. When this function is called, this function is regarded as this object a method.
var obj={ //some code; }; obj.getname=function(){ //some name } obj.getname(); 函数的上下文是这个对象(例子中的 obj)。this->obj
3. Constructor calling mode (this->new object created)
When the function is called as a constructor, it has the following characteristics:
A new object is created;
This new object is passed to the constructor as the this parameter, which means that this new object is the context of the constructor function;
If there is no explicit return statement, this new object will be returned implicitly (that is, it will be returned quietly) and become the value of this constructor.
function Fn(){ this.a=function(){ return this; } } var n=new Fn(); console.log(n.a());//Fn{a:f} console.log(n);//fn{a:f} //此例中,构造了一个构造函数Fn((),利用new关键字调用时一个空的对象被创建出来,并传递到函数中作为this存在。this-Fn(新的) //这个构造器同时创建了a属性,并将此属性作为一个方法赋予给它创建出新对象的实例。
4.apply() gets the call() method (this-> can be any object we specify)
(1) apply(), two parameters. First parameter: the object used as the function context. Second parameter: a parameter array.
(2) call(), two parameters. First parameter: the object used as the function context. The second parameter: argument list.
call() and apply() are mostly used for function callbacks.
function circle(list,calback){ for(var i=0;i<list.length var circle>call()传递进来的第一个参数。</list.length>
Related recommendations:
WeChat Detailed explanation of data data operations and function calls in mini program Page
How to solve the problem of undefined function when js parent function calls child function
The above is the detailed content of Detailed explanation of different ways of function calling and the pointing of this. For more information, please follow other related articles on the PHP Chinese website!

编程语言用来以计算机可以理解的语言给计算机发出指令。计算机语言分为三种类型,如下所示:机器语言符号语言高级语言机器语言计算机是一台机器。由于它的内存只能存储1和0,必须以一串1和0的流的形式给计算机发出指令,即二进制代码。这些对机器来说很容易理解。以二进制代码编写的程序可以直接输入计算机执行,这被称为机器语言。机器语言的优点包括:执行速度非常快。很难编写和阅读机器语言的程序。机器指令很难记住。符号语言也称为汇编语言。汇编程序包含“助记符”。“助记符”是指以缩写的形式很容易记住的信息。符号语言的优

Go语言作为一个现代化的编程语言,时间在开发中占有很重要的位置。Go语言提供了一些内置的时间函数和结构体,使得时间的处理变得更加便捷。在本篇文章中,将会介绍一些Go语言中常用的时间处理方式。time.Now()我们可以使用time.Now()函数获取当前的时间:now:=time.Now()fmt.Println(now)输出:2019-06-131

Chrome会自动在地址栏中记录曾经输入过的网址,并且会在未来自动“联想查询内容”,但很多时候我们并不需要一些网址,如何删掉它们呢?小编经常遇到这样的困扰,曾经输入过的地址,会挡在常用地址的前面,导致需要选好几次才能进入需要的网站。为此我也找过至少3次如何删除了,因为…每次都会忘记。在Chrome官方帮助Chrome键盘快捷键的地址栏快捷键中,就明确了删除快捷键:▍Windows删除地址栏联想内容按向下箭头键以突出显示相应内容,然后按Shift+Delete键▍macOS删除地址栏联想内容按向下

同事因为this指向的问题卡住的bug,vue2的this指向问题,使用了箭头函数,导致拿不到对应的props。当我给他介绍的时候他竟然不知道,随后也刻意的看了一下前端交流群,至今最起码还有70%以上的前端程序员搞不明白,今天给大家分享一下this指向,如果啥都没学会,请给我一个大嘴巴子。

link与import之争:它们有何不同之处?在开发和编程中,我们经常需要与其他文件或模块进行交互。为了实现这种交互,链接(linking)和导入(importing)是两种常用的方式。然而,许多人可能并不清楚link和import有什么不同之处以及何时使用它们。本文将详细介绍link和import的区别,并提供代码示例。首先,我们来了解link的概念。链接

win7系统是微软的传统操作系统,有很多实用功能,比如win7系统还原点的作用。win7设置还原点,可以win7还原系统到还原点,达到系统修复的目的。win如何设置还原点?下面小编教你win7设定还原点的方式。win7设定还原点的方式1.找到桌面电脑快捷方式,右键选择属性。2.进入属性设置后,选择高级系统配置。3.在弹出的系统属性框中选择系统维护选项。4.点击立即为开启系统保护的控制器建立还原点。5.添加还原点的描述,然后点击建立,耐心等待一会儿,成功建立还原点,然后点击关闭,下次应用还原系统可

xp系统可以说成微软很早以前出的电脑上系统,现阶段应用的人非常少,关键是在老电脑上应用.有许多网民想将xp系统升级win7应用,可是不清楚xp系统怎么升级win7.下边就演试下实际的操作步骤.1、下载安裝新手三步电脑装机版手机软件并开启,选择win7系统,点一下马上重新安装。2、等候专用工具全自动下载win7系统。3、下载进行后立即开展在线重装Windows系统,请依据提醒实际操作。4、安裝结束后,可以选择马上重新启动。5、进到运行菜单栏,选择第二项XiaoBaiPE-MSDNOnlineIns

jQuery与CSS3动画功能有何不同?优劣对比引言:如今,网页设计已经越来越注重用户体验。而动画效果作为增强用户体验的重要手段之一,在网页设计中扮演着重要角色。在实现动画效果的过程中,开发者面临着选择使用jQuery还是CSS3动画的问题。本文将对两者进行对比分析,探讨其优劣之处,并为读者提供相关代码示例。一、jQuery动画:jQuery是一款功能强大的


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

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.

Notepad++7.3.1
Easy-to-use and free code editor

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.

Dreamweaver CS6
Visual web development tools

ZendStudio 13.5.1 Mac
Powerful PHP integrated development environment
