troubleshooting Question

JavaScript - Loss of scope in event handlers - self/this

Avatar of Dale Burrell
Dale BurrellFlag for New Zealand asked on
JavaScript
6 Comments1 Solution315 ViewsLast Modified:
Guys,

Its a common problem with a common soloution and I've used it loads myself... but I'm missing something probably quite obvious here in understanding why the solution actually works.

See following code, I'm creating and assigning an event handler and prior to creating the event handler I'm making a reference 'self' to the 'this' pointer so that I can access it when the event handler is called. Now I understand why the 'this' pointer is no longer in scope... what I don't understand is why a local variable, 'self', IS in scope when called from within the event handler. So if someone could clarify that small point for me I'llk be very happy...

Cheers Dale - Code follows...

    this.makeRequest = function()
    {
        if (this.Init())
        {
            this.request.Open(this.method, this.url, this.async);
            var self = this;
            this.request.onreadystatechange = function()
            {
                if(self.request.readyState == 4)
                {
                }
            }
            this.request.send(this.postData)
        }
        else alert ("Failed to open connection");
    }
ASKER CERTIFIED SOLUTION
dakyd

Our community of experts have been thoroughly vetted for their expertise and industry experience.

Log in to continue reading
Become an EE member today7-DAY FREE TRIAL
Members can start a 7-Day Free trial then enjoy unlimited access to the platform for $9.99/mo
View membership options
Unlock 1 Answer and 6 Comments.
or
Learn why we charge membership fees
We get it - no one likes a content blocker. Take one extra minute and find out why we block content.
See how we're fighting big data
The Value of Experts Exchange in My Daily IT Life

Experts Exchange (EE) has become my company's go-to resource to get answers. I've used EE to make decisions, solve problems and even save customers. OutagesIO has been a challenging project and... Keep reading >>

Mike

Owner of Outages.IO
Phoenix, Arizona, United States
Member Since 2016
Join a full scale community that combines the best parts of other tools into one platform.
Unlock 1 Answer and 6 Comments.
View membership options
“All of life is about relationships, and EE has made a virtual community a real community. It lifts everyone's boat.”
William Peck

Member since 2004