전문 인터넷 중독자 • 게임 애호가 • 기술 창작자
전문 인터넷 중독자 • 게임 애호가 • 기술 창작자

JavaScript Object.defineProperty를 사용하여 게터 및 설정을 만듭니다.

JavaScript의 Object.defineProperty 덕분에 더 이상 getter 및 setter 함수가 필요 없습니다!
이 페이지는 여러분의 편의를 위해 열정적인 AI 인턴들이 영어에서 번역한 것입니다. 아직 학습 중이므로 몇 가지 오류가 있을 수 있습니다. 가장 정확한 정보는 영어 버전을 참조하세요.
블로그 JavaScript Object.defineProperty를 사용하여 게터 및 설정을 만듭니다.

이 블로그 게시물은 2013년 4월에 게시되었으므로, 읽는 시점에 따라 일부 내용이 최신이 아닐 수 있습니다. 안타깝게도 정보의 정확성을 보장하기 위해 게시물을 항상 최신 상태로 유지하는 것은 어렵습니다.

    Coming from 15 years of Java development, writing (probably thousands of) traditional setters and getters methods in various Java classes has been so deeply rooted in my backbone.
    /* * A Java class with traditional setters and getters */ public class Person { private String name; public void setName(final String name) { this.name = name; } public String getName() { return name; } }
    As a developer you write this because you want to maintain data encapsulation, meaning the only way to get the Person's name is through the public getName method. I could have made the name variable public directly as well, like this:
    /* * A Java class with only public variables */ public class Person { public String name; }
    However, by doing this it would not be possible to add extra functionality when someone retrieves the name, such as the returned name should be "John Doe" if no name has been set:
    /* * A Java class with extra functionality in the getter */ public class Person { private String name; public String getName() { return name == null ? "John Doe" : name; } }
    In JavaScript you could do the same thing (simple example, not using the prototype object):
    /* * A simple JavaScript example */ var Person = function() { var name; this.getName = function() { return this.name ? this.name : "John Doe"; } }; var someone = new Person(); console.log( someone.getName() );
    However, the problem (in my opinion) with getters and setters functions is the increased boilerplate code. Everywhere you constantly need to write:
    var name = person.getName();
    instead of directly and maybe more readable:
    var name = person.name;
    Now you maybe ask yourself, won't we have the same problem in JavaScript, like in Java, if we would like the "John Doe" functionality? Actually no - and this is thanks to the Object.defineProperty function in the JavaScript language.
    With Object.defineProperty you can define a property on an object and even define the functionality behind it when the property is read or assigned. Here is an example:
    /* * A JavaScript example using Object.defineProperty */ var Person = function() { }; Object.defineProperty(Person.prototype, "name", { get: function() { return this._name ? this._name : "John Doe"; } }); var someone = new Person(); console.log( someone.name );
    Please note that in the example above, I add the name property on the prototype object and not directly on the Person object (to increase performance).
    In my opinion this is really simple and very elegant. You decrease boilerplate code throughout your whole solution, but still achieve data data encapsulation - and that's very cool :-)

    Special Agent Squeaky님이 작성했습니다. 최초 게시일 2013년 4월 1일, 최종 업데이트일 2013년 4월 1일.

    📺 스퀴키의 최신 영상을 시청하세요!

    라이브 스트림에 간단한 실시간 자막을 추가하는 방법