> 웹 프론트엔드 > JS 튜토리얼 > 평가를 사용하지 않고 문자열에서 자바 스크립트 함수를 호출하는 방법

평가를 사용하지 않고 문자열에서 자바 스크립트 함수를 호출하는 방법

Lisa Kudrow
풀어 주다: 2025-02-22 10:40:10
원래의
759명이 탐색했습니다.

How to Call a JavaScript Function From a String Without Using eval JavaScript에서

는 좋은 생각이 아닙니다! MDN의

페이지는 다음과 같습니다. & gt; 브라우저는 여전히 지원하지만 새로운 프로젝트에서는 권장되지 않습니다. 사용하지 마십시오. eval 코드가 포함 된 문자열을 실행합니다. eval

몇 가지 문제가 발생합니다 :

eval 보안 :

는 타사 스크립트 또는 사용자 입력에 의해 문자열이 다른 명령에 주입 될 수 있습니다.
eval("var x = 'Hello from eval!';");
console.log(x);
로그인 후 복사
로그인 후 복사
<🎜 🎜> <<> 디버그 :

디버그 오류가 어렵습니다. 라인 번호 나 명백한 오류 포인트가 없습니다. eval <🎜 🎜> <<> 최적화 :

javaScript 통역사는 코드가 변경 될 수 있으므로 코드를 사전 컴파일 할 수는 없습니다. 통역사가 더욱 효율적으로 증가하고 있지만 거의 확실하게 기본 코드보다 느리게 실행됩니다.
  1. <<> 불행히도, 는 매우 강력하고 경험이 부족한 개발자는이 명령을 쉽게 과도하게 사용할 수 있습니다. 경고에도 불구하고 <<>는 여전히 엄격한 모드에서도 작동하지만 일반적으로 피할 수 있습니다. 과거에는 주로 JSON 줄을 사로화하는 데 사용되었지만 이제는 더 안전한 방법이 있습니다. 그러나 문자열에 함수 이름이있는 경우 예를 들어 :
  2. <🎜 🎜>를 사용하지 않고 함수를 어떻게 실행합니까? 최근에 HTML5 히스토리 API를 사용하는 동안이 문제를 겪었습니다. 객체를 직렬화하는 웹 워커 나 다른 API를 사용할 때 비슷한 도전에 직면 할 수 있습니다.
  3. 가없는 가장 쉽고 안전한 구현 솔루션은 다음과 같은 일련의 조건입니다.
  4. <,> 안전하지만 수십 개의 기능을 부르려면 글을 쓰는 것은 매우 비효율적이고 두통입니다. 더 나은 솔루션은 현재 창과 모든 항목을 참조하는 객체를 사용하는 것입니다. <<<>가 <🎜 🎜>에서 객체로 사용할 수 있는지 확인할 수 있으며 함수인지 예를 들어 실행하십시오. 필요한 경우 추가 점검을 수행하여 함수에 예상 이름이 있는지 확인할 수 있습니다. 우리가 호출하는 함수에 매개 변수가 있다면 어쩌면 어쩌면 배열에 저장 될 수 있습니까? 문제 없음; 우리는 단지
  5. 방법을 사용하면됩니다
그래서 이것이 <🎜 🎜> 사용을 중단 해야하는 또 다른 이유입니다. 또한이 솔루션은 더 안전하고 오류가 적고 디버그가 더 쉽고 실행하기가 더 빠릅니다. 그것이 당신에게 도움이되기를 바랍니다.

<🎜 🎜 <🎜

를 사용하지 않고 문자열에서 JavaScript 함수를 실행할 때 FAQ <🎜 🎜>를 사용하지 않고 문자열로 JavaScript 함수를 호출하는 의미는 무엇입니까? eval

javaScript의 <🎜 🎜> 함수는 임의의 코드 문자열을 실행할 수있는 강력한 도구입니다. 그러나

를 사용하는 것은 종종 보안 및 성능 문제로 인해 나쁜 관행으로 간주됩니다. 코드를 주입 ​​공격에 취약하게 만들 수 있습니다. 또한 최신 JavaScript 엔진은 코드의 성능을 최적화하지만 <🎜 🎜>에 의해 실행 된 코드를 최적화 할 수는 없습니다. 따라서 <🎜 🎜>를 사용하지 않고 문자열로 JavaScript 함수를 호출하는 방법을 아는 것이 매우 유익합니다. 이것은 더 안전하고 효율적인 대안 인 eval() 객체 또는

생성자를 사용하여 달성 할 수 있습니다.

<<> eval() 객체를 사용하여 문자열을 사용하여 JavaScript 함수를 호출하는 방법은 무엇입니까? eval() eval() javaScript의 eval() 객체는 브라우저에 표시된 창을 나타냅니다. 브라우저 환경의 글로벌 객체이며 모든 글로벌 변수와 함수는 window 객체의 속성과 방법이됩니다. <<> 객체를 사용하여 Function 객체의 특성으로 함수에 액세스하여 문자열을 사용하여 함수를 호출 할 수 있습니다. 예는 다음과 같습니다.

이 코드에서 "hello"는

객체의 속성으로 <🎜 🎜> 함수를 나타냅니다. 그러므로 는 <🎜 🎜> 함수를 호출합니다. window <<> a

생성자 란 무엇입니까? 문자열을 사용하여 함수를 호출하는 방법은 무엇입니까?

window javaScript의 window 생성자는 새로운 <🎜 객체를 만듭니다. 이것은 덜 일반적이지만 여전히 함수를 정의하는 효과적인 방법입니다. 문자열을 생성자로 전달하여 <<> 생성자를 사용하여 문자열을 사용하여 함수를 호출 할 수 있습니다. 예는 다음과 같습니다. window <,>이 코드에서 window 생성자는 두 개의 인수 "a"와 "b"를 취하고 합계를 반환하는 새로운 함수를 만듭니다. 매개 변수 및 기능 본체는 문자열로 전달됩니다.

함수가 객체의 메소드 인 경우 문자열을 사용하여 함수를 호출 할 수 있습니까?
eval("var x = 'Hello from eval!';");
console.log(x);
로그인 후 복사
로그인 후 복사
예, 함수가 객체의 메소드 인 경우에도 문자열을 사용하여 함수를 호출 할 수 있습니다. 객체의 속성에 액세스하여이를 수행 할 수 있으며, 이는

객체를 처리하는 방법과 유사합니다. 예는 다음과 같습니다. window 이 코드에서 "hello"는 hello() 메소드를 참조하는 객체의 속성입니다. 그러므로 는 메소드를 호출합니다. window["hello"] 문자열을 사용하여 JavaScript 함수를 호출하는 한계는 무엇입니까?

어떤 경우에는 문자열을 사용하여 JavaScript 함수를 호출하는 것이 유용 할 수 있지만 몇 가지 제한 사항도 있습니다. 한 가지 제한 사항은 글로벌 기능 또는 알려진 객체의 메소드에만 적용된다는 것입니다. 함수가 알려진 객체의 속성이 아닌 경우 문자열로 호출 할 수 없습니다. 또 다른 한계는 매개 변수를 함수로 직접 전달할 수 없다는 것입니다. 함수가 매개 변수를 허용하는 경우 매개 변수를 문자열에 포함 시키거나 다른 함수를 사용하여 전달해야합니다. 이러한 한계에도 불구하고, 문자열로 함수를 호출하는 것은 여전히 ​​올바르게 사용될 때 강력한 도구입니다.

위 내용은 평가를 사용하지 않고 문자열에서 자바 스크립트 함수를 호출하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿