as shown in the figure, why does this point to windows/undefined, after calling obj.getAge ()? isn"t obj calling it? shouldn"t this point to obj?
:personshowNamethispersonthis
as shown in the figure, why does this point to windows/undefined, after calling obj.getAge ()? isn"t obj calling it? shouldn"t this point to obj?
:personshowNamethispersonthis
because fn is an anonymous function
give a simple example
var obj = {
fn1: function() {
console.log(this);//obj
var noNamed = function() {
console.log(this);//windowd
};
return noNamed();
}
};
obj.fn1();
above, your var fn=function () {};
then return fn ()
is essentially a directly called anonymous function closure return function () {}
you just assign this anonymous function to fn, and it doesn't change the nature that he doesn't have a function name
conclusion: as long as it is an anonymous function, this points to the window global object, for example:
function foo() {
var fn = setTimeout(function() { //
console.log(`setTimeoutthisfoo:${this.age}`);
}, 0);
}
foo.call({
age: '1000'
});//undefined
var name = 'XL';
var person = {
name: 'xl',
showName: function() {console.info(this.name)}
}
person.showName ();
/ / where the showName call location is the person context, so the active this is bound to the person
var showNameA = person.showName;
/ / the showNameA here is similar to the function alias, showNameA is a reference to person.showName, and the showNameA call location is still window.
/ / the binding of this is related to its call location
var obj = {
birth: 1990,
getAge: function() {
var b = this.birth;
var fn = function() { console.info(this)}
}
return fn;
}
the getAge in your obj involves closures, which can actually be understood as returning a function fn,obj.getAge () to continue to execute fn, after completion. The location of the call at this time is in the Window environment, so the this in fn points to window
.this doesn't understand
The horizontal coordinates of echarts are not specifically marked, and the X coordinates do not have a grid to indicate. Here is a figure that specifies . js * * createChartSix() { this.$http .get(this.$api.dataChart) .then(rsp => { ...
sincerely ask for advice: < hr > I want to use node as the background to build a video streaming server. The front end is similar to Youku VOD. It can record the playback node function, and load the progress bar at any point (starting from the c...
I need to implement in a chained promise function, any function error in the middle terminates the program, and can catch the error function, and then perform different operations according to different error functions. How can the following code be imp...
I would like to ask what is wrong with this code. Thank you for your answers. ...
is doing a question on Niuke.com. I encounter a problem: to achieve the function callIt, after the call meets the following conditions 1, the returned result is the result after calling fn 2, and the call parameter of fn is all the parameters after th...
A timing examination system is triggered if the click event is triggered within 5 seconds, and if it is not triggered, the system marks the correct answer at the end of the countdown. How to implement ...
description: a regular match is given to the content of an input box, and the matching content is the product activation code. looks like this: "0C31-0B81-BB32-3094-0C31-0B81-BB32-3094 " Code: $( -sharplicenseCode ).keyup(function () { le...
1. The custom event triggers the click event of .cpcstartrefresh, but triggers 2 click events each time 2. The code is as follows: window.onmessage = function (e) { create an event object, var myEvent = document.createEvent( Event ); m...
I configured the MIME type of the file with the amr suffix in the apache configuration as application ms-download, Why it is a garbled page when opening a file in amr format using window.open in chrome, while a file in amr format can be successfully dow...
I got a set of data, which is to choose the type of question. How can I tell if I have chosen the right one answera: "Olympic Games " answerb: "Asian Games " answerc: "Paralympic Games " answerd: "University Games " id: "1772 " question: "f...
read a number, such as 521 change this number to 0521 but put it into four div separately, how to realize it? 0 < div > 5 < div > 2 < div > 1 < div > ...
react projects cannot save store? using redux, data index.js ReactDOM.render( <Provider store={store}> <Router > < Provider>, document.getElementById( root )) registerServiceWorker() actions export const SET_USER = ...
how to find all the NA characters in a HMLT page and replace it with "and invalid " with native JS ...
...
suppose there are only a.js and b.js (only two js and nothing else) b.js export A variable is used for a.js can you directly use import and export without using packaging and compilation tools such as webpack or babel can it be achieved with the h...
do the gods have plug-ins for uploading attachments in the mobile version that can also be uploaded more than one? ...
what does the code circled in the following picture mean? ...
I look at a html ui project with items such as: var apiserver = window[ apiserver ]; url = apiserver + "filterUrlController getUrlData"; I searched the whole project and couldn t find the value of window [ apiserver ]. How do you un...
In the vue-cli project, I directly introduced the particls library into index.html, and the related files are placed in the static directory . <div id="particles-js">< div> <script type="text javascript" src="s...
How does the code return only the result after the last asynchronous operation in the for loop is completed as shown in the figure? Please stop by and give me a hand. ...