Home > Web Front-end > JS Tutorial > When Do JavaScript Object Variables Need 'this'?

When Do JavaScript Object Variables Need 'this'?

Barbara Streisand
Release: 2024-12-15 08:23:10
Original
616 people have browsed it

When Do JavaScript Object Variables Need

Do Javascript Object Variables Require "this"?

In Javascript, the concept of classes differs from languages like C . Class-based inheritance is lacking, making way for prototypical inheritance. Objects and their properties play a crucial role.

When constructing an object using a constructor function, the "this" keyword grants access to the object's properties. Consider the following example:

function Foo() {
    this.bar = 0;
}
Copy after login

In this constructor, the "this" keyword associates the "bar" property with the created object. Failure to use it would result in the error "bar is undefined."

However,开发者发现了一个技巧,使用构造函数作为闭包,创造私人"属性":

function Foo() {
    var bar = "foo";
    this.getBar = function getter() {
        return bar;
    };
}
Copy after login

In this example, the variable "bar" is declared locally, while "getBar" is a privileged method that accesses it. This technique allows the creation of private variables that cannot be modified externally.

It's essential to note that methods declared on the prototype do not have access to local variables within the constructor. However, they can utilize privileged methods. In the following code, the prototype method "getFooBar" uses the "getBar" method to concatenate a suffix:

Foo.prototype.getFooBar = function() {
    return this.getBar() + "bar";
}
Copy after login

This allows for the creation of both public (prototype methods) and private (privileged methods) properties within a single object.It's important to consider memory usage as privileged methods create distinct function objects with different scope chains. For large amounts of instances, prototype methods are preferred.

The above is the detailed content of When Do JavaScript Object Variables Need 'this'?. For more information, please follow other related articles on the PHP Chinese website!

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
Latest Articles by Author
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template