"일꾼이 일을 잘하려면 먼저 도구를 갈고 닦아야 한다." - 공자, 『논어』.
첫 장 > 프로그램 작성 > 'eval' 없이 JavaScript에서 런타임 이름이 지정된 함수를 만들 수 있나요?

'eval' 없이 JavaScript에서 런타임 이름이 지정된 함수를 만들 수 있나요?

2024년 11월 15일에 게시됨
검색:802

Can You Create Runtime-Named Functions in JavaScript Without `eval`?

JavaScript에서 Eval이 없는 런타임 이름이 지정된 함수

평가 또는 색다른 엔진 관련 기능을 사용하지 않고 런타임에 결정된 이름으로 JavaScript 함수를 생성할 수 있습니까? ? 예, 이제 ECMAScript 2015(ES6) 이상에서 가능합니다.

ES6 솔루션: 계산된 속성 이름

ES6에서 객체 속성에 할당된 익명 함수 표현식은 해당 속성의 이름을 사용합니다. 재산. 이는 계산된 속성 이름과 결합되어 new Function 또는 eval 없이 함수 이름을 지정할 수 있습니다. 예:

const dynamicName = "foo"   Math.floor(Math.random() * 1000);
const obj = {
    [dynamicName]() {
        throw new Error();
    },
};
const f = obj[dynamicName];

이것은 "foo###"라는 함수를 생성합니다. 여기서 ###는 임의의 1~3자리 숫자입니다.

함수 이름 가시성

함수의 이름 속성은 동적 이름을 반영합니다. 위 코드 조각의 호환성 참고 사항은 Edge와 Safari가 현재 스택 추적에 이름을 표시하지 않는다는 사실을 나타냅니다.

최신 튜토리얼 더>

부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.

Copyright© 2022 湘ICP备2022001581号-3