Can 'this' ever be null in Javascript

2019-01-22 12:11发布

I have a function along the lines of the following:

    doSomething: function () {
        var parent = null;

        if (this === null) {
            parent = 'some default value';
        } else {
            parent = this.SomeValue();
        }
    }

Could parent ever be set to 'some default value' or is the check for null superfluous?

Alternatively, what if I used the less restrictive:

    doSomething: function () {
        var parent = this ? this.SomeValue() : 'some default value';
    }

Could parent ever be set to 'some default value' in this case?

6条回答
迷人小祖宗
2楼-- · 2019-01-22 12:21

In non-strict mode, this has undergone an Object(this) transformation, so it's always truthy. The exceptions are null and undefined which map to the global object. So this is never null and always truthy, making both checks superfluous.

In strict mode, however, this can be anything so in that case you'd have to watch out. But then again you have to opt in for strict mode yourself, so if you don't do that there are no worries.

(function() {               return this; }).call(null); // global object
(function() { "use strict"; return this; }).call(null); // null

The specification of ES5 says:

The thisArg value is passed without modification as the this value. This is a change from Edition 3, where a undefined or null thisArg is replaced with the global object and ToObject is applied to all other values and that result is passed as the this value.

查看更多
Lonely孤独者°
3楼-- · 2019-01-22 12:23

The this keyword shouldn't ever be null, but it might not be what you expect. You can end up referencing the window object if you're not careful.

In your case, I believe this should refer to the doSomething function.

var myObject = {
    myMethod: function() {
        console.log(this);
    }
};

myObject.myMethod(); // prints out a reference to the myMethod function

Here's a jsFiddle.

查看更多
迷人小祖宗
4楼-- · 2019-01-22 12:29

You can see what occurs if you try to force Javascript to use a null scope in any browser. I made an example here:

http://jsfiddle.net/rXsWj/

In short, this empirically proves that the browser changes 'null' to 'window' on the fly. If instead you change null to 'a', you'll see an alert of 'a' like you would expect. Code from link as reference:

function a() {
    alert(this)
}

a.apply(null)

查看更多
别忘想泡老子
5楼-- · 2019-01-22 12:29

No. The value of this will never be the text 'some default value'.

查看更多
成全新的幸福
6楼-- · 2019-01-22 12:34

this can not be null. if it was null, then you couldn't be in method scope.

查看更多
做自己的国王
7楼-- · 2019-01-22 12:35

Although not a direct answer to your question.. in a browser 'this' will, by default, refer to the 'window' object. On nodejs it will refer to the global object.

I'm not sure if there's ever a case where it could be null, but it would at the very least be unusual.

查看更多
登录 后发表回答