JavaScript Introducing ES2015 Classes Getter and Setter Methods

Getters and setters

What is the point of getter and setters? Aren't they just simply methods on an object? Clarification on this would be extremely helpful!

1 Answer

Øivind Berg Jullum
Øivind Berg Jullum
Full Stack JavaScript Techdegree Graduate 43,923 Points


Indeed, getters and setters are just methods (functions) under the hood. But the point is that they look like normal properties when you use them.

On reason you might want to do this is instead of defining for example two methods such as (getFullName) and (setFullName). You could just have one getter / setter just called (fullName). So, its just a bit of neat-ness or syntactic sugar.

Consider this example:

// Define a simple object, person
var person = {
    firstName: 'John',
    lastName: 'Smith'

// Dont worry about this syntax. This is the old ES5 way do define getters and setters.
Object.defineProperty(person, 'fullName', {
    get: function() {
        return this.firstName + ' ' + this.lastName;
    set: function(aName) {
        var names = aName.split(' ');

        this.firstName = names[0];
        this.lastName = names[1];

// The point is we arive at this.
console.log(person.fullName); // John Smith

person.fullName = 'Jane Doe';

console.log(person.firstName); // Jane
console.log(person.lastName); // Doe

Remember tho, that a setter can only take one argument, because you can only have one value or expression after the assignment operator. ;)

Tom Geraghty
Tom Geraghty
24,148 Points

Great answer! I just wanted to add on that doing things in this way will hide some implementation details for people utilizing your classes.

So if you're writing an API for someone to use in the future, you can tell them they can use this class object property name and it will return what they want returned without you telling them exactly how that information was created and returned. That can prevent people from trying to coerce your program into doing things or revealing information it is not supposed to.

Hope that helps!