Home > Web Front-end > JS Tutorial > Usage example analysis of JS function this_javascript skills

Usage example analysis of JS function this_javascript skills

WBOY
Release: 2016-05-16 16:15:42
Original
1148 people have browsed it

The example in this article describes the usage of JS function this. Share it with everyone for your reference. The details are as follows:

When writing functions in js, this is used a lot. What exactly is this? This is a keyword and a pointer, pointing to the execution environment scope, also called context.
Let’s talk about functions first. My personal understanding is that functions are code blocks that are called repeatedly in the language.
In JS, when assigning a function to a property of an object, it is called a method
Such as:

var m={};
m.title='title';
m.show=function(){
alert(this.title)
}
m.show()

Copy after login

Is to call the function as a method of object m
In this case, this points to the object m.

Directly calling the function name is called a function:

var a=1212;
function show(){
alert(a)//1212
}
show()// 1212

Copy after login

In the global environment, global variables can be understood as properties of window, and global functions are methods of window
Look at the example below:

var m ={};
m.id='mmm';
m.show=function(){
  alert(this.id);
}
var a={};
a.id='aaa';
a.show=m.show;
a.show(); //aaa

a.show=m.show;  先理解这句话,因为函数是个对象,
m.show=function(){
  alert(this.id)
}

Copy after login

This expression is equivalent to a.show and m.show simultaneously referencing

function(){
  alert(this.id)
}
Copy after login

is actually equivalent to

a.show=function(){
  alert(this.id)
}
Copy after login

So when calling a.show(), this points to the a object,
Take a look at the following chestnut

var m ={};
m.id='mmm'
m.show=function(){
  alert(this.id)
}
var a={}
a.id='aaa'
a.show=function(){
  m.show()
};
a.show(); //mmm
Copy after login

So when calling a.show(), it is equivalent to calling the m.show() method, so this. points to the m object.

Look at the following example again. I still don’t understand it at first

var color='red';
var app = {};
app.color="green";
app.paint=function(node){
node.style.color=this.color;
  alert(this.color);
}
function findNode(callback){
  var btn =document.querySelector('.btn');
  callback(btn);//传进来,
}
findNode(app.paint);
alert(this.color); //red 而不是green

Copy after login

When function parameters are passed, parameters are passed by value, not by reference

So when findNode(app.paint); is passed in, it is actually

function(node){
  node.style.color=this.color;
  alert(this.color);
}
Copy after login

reference, and because findNode is globally defined, this points to WINDOW OR UNDEFINED;

About passing parameters, pass them by value

function show(a){
  alert(a)
}
Copy after login

Easy to understand when the parameters are basic data types

var b=10;
show(b)//alert(10);
Copy after login

As for the object

var c ={};
c.prop=true;
var showProp=function(obj){
obj.prop=false
}
showProp(c); //c.prop = false
Copy after login

Some people think that the above example is passing parameters by reference
In fact, the parameters above are still passed by value. When showProp(c) passes c into the function, c is actually equivalent to a reference. Obj.prop=false in the function is equivalent to changing the referenced object to {prop:false}

Look at the following example

var c ={};
c.prop=true;
var showProp=function(obj){
  obj = new Object();
  obj.prop=false
  return obj;
}
showProp(c);
alert(c.prop); //true
Copy after login

The incoming obj has been modified here. If parameters are passed by reference according to the function, the modifications in the function will definitely be reflected externally

I hope this article will be helpful to everyone’s JavaScript programming design.

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