개발자 Q&A

개발하다 막혔다면? 여기서 질문하세요! 초보부터 고수까지, 함께 고민하고 해결하는 공간입니다. 누구나 자유롭게 질문하고 답변을 남겨보세요!

2025.07.30 16:04

Object.defineProperty(obj, prop, descriptor) 사용 시 에러 발생

목록
  • 버전컨트롤러 2일 전 2025.07.30 16:04
  • 5
    1
저는 Object.defineProperty(obj, prop, descriptor) 함수를 사용하여 객체의 속성을 정의하고자 하는데, 에러가 발생하고 있습니다.

1. descriptor의 속성 중 writable, configurable, enumerable은 각각 어떤 역할을 하며, default 값은 무엇인가요?
2. writable 속성을 false로 설정하였는데, 이 경우 속성값을 변경하려고 할 때 어떻게 처리되는가요?
3. descriptor의 get, set 함수를 사용하는 경우, 이 함수는 어떤 역할을 하며, 어떻게 호출되는가요?

    댓글목록

    profile_image
    나우호스팅  2일 전



    1. writable, configurable, enumerable 속성은 객체의 속성을 정의할 때 사용하는 속성입니다.
    - writable 속성은 속성을 읽기만 가능하도록 설정할 때 사용됩니다. writable 속성의 default 값은 true입니다.
    - configurable 속성은 속성을 삭제하거나 재정의할 때 사용됩니다. configurable 속성의 default 값은 false입니다.
    - enumerable 속성은 속성을 반복문으로 순회할 때 표시할 때 사용됩니다. enumerable 속성의 default 값은 false입니다.

    2. writable 속성을 false로 설정하면 속성값을 변경하려고 할 때 에러가 발생하지 않고 속성값이 변경되지 않습니다. 이 경우 속성값은 읽기 전용이 됩니다.

    3. descriptor의 get, set 함수는 속성값의 getter, setter 함수를 정의할 때 사용됩니다.
    - get 함수는 속성값을 읽을 때 호출됩니다. get 함수는 반드시 return 값을 반환해야 합니다.
    - set 함수는 속성값을 변경할 때 호출됩니다. set 함수는 속성값을 인수로 받습니다.

    예를 들어, 다음 코드는 속성값의 getter, setter 함수를 정의한 예입니다.

    #hostingforum.kr
    javascript
    
    let obj = {};
    
    
    
    Object.defineProperty(obj, 'name', {
    
      value: 'John',
    
      writable: false,
    
      enumerable: true,
    
      configurable: true,
    
      get: function() {
    
        return this.value;
    
      },
    
      set: function(value) {
    
        console.log('속성값이 변경되었습니다.');
    
        this.value = value;
    
      }
    
    });
    
    
    
    console.log(obj.name); // John
    
    obj.name = 'Jane';
    
    console.log(obj.name); // Jane
    
    


    위 코드에서, 속성값의 getter 함수는 속성값을 읽을 때 호출되며, 속성값의 setter 함수는 속성값을 변경할 때 호출됩니다. 속성값의 setter 함수는 속성값을 인수로 받습니다.

    2025-07-30 16:05

  • 개발자 Q&A 포인트 정책
      글쓰기
      50P
      댓글
      10P
  • 전체 40,729건 / 4 페이지

검색

게시물 검색