> 웹 프론트엔드 > JS 튜토리얼 > JavaScript 함수 매개변수 이름 및 값을 동적으로 검색하려면 어떻게 해야 합니까?

JavaScript 함수 매개변수 이름 및 값을 동적으로 검색하려면 어떻게 해야 합니까?

Barbara Streisand
풀어 주다: 2024-12-06 10:46:11
원래의
217명이 탐색했습니다.

How Can I Dynamically Retrieve JavaScript Function Parameter Names and Values?

JavaScript에서 동적으로 함수 매개변수 세부정보를 검색하는 방법

일부 시나리오에서는 함수의 매개변수 이름과 값에 동적으로 액세스해야 합니다. 이 문서에서는 이 문제에 대한 강력한 솔루션을 살펴봅니다.

매개변수 이름 추출 기능

다음 함수인 getParamNames는 제공된 함수의 매개변수 이름을 추출할 수 있습니다.

var STRIP_COMMENTS = /((\/\/.*$)|(\/\*[\s\S]*?\*\/))/mg;
var ARGUMENT_NAMES = /([^\s,]+)/g;

function getParamNames(func) {
  var fnStr = func.toString().replace(STRIP_COMMENTS, '');
  var result = fnStr.slice(fnStr.indexOf('(')+1, fnStr.indexOf(')')).match(ARGUMENT_NAMES);
  if(result === null)
     result = [];
  return result;
}
로그인 후 복사

사용 및 예

getParamNames(getParamNames) // returns ['func']
getParamNames(function (a,b,c,d){}) // returns ['a','b','c','d']
getParamNames(function (a,/*b,c,*/d){}) // returns ['a','d']
getParamNames(function (){}) // returns []
로그인 후 복사

참고: 기본값 처리 매개변수

ES6의 출현으로 기본 매개변수가 getParamNames 함수를 작동시킬 수 있습니다. 이 문제를 해결하기 위해 업데이트된 버전이 제공됩니다.

var STRIP_COMMENTS = /(\/\/.*$)|(\/\*[\s\S]*?\*\/)|(\s*=[^,\)]*(('(?:\'|[^'\r\n])*')|("(?:\"|[^"\r\n])*"))|(\s*=[^,\)]*))/mg;
로그인 후 복사

이 향상된 버전은 대부분의 경우 기본 매개변수를 처리하지만 예외가 발생할 수 있습니다.

매개변수 값 검색

에서 매개변수 이름을 얻는 것 외에도 해당 값이 필요할 수도 있습니다. 이는 배열로 변환할 수 있는 로컬 변수 인수를 통해 쉽게 액세스할 수 있습니다.

var args = Array.prototype.slice.call(arguments);
로그인 후 복사

또는 배열 제네릭을 사용할 수 있는 경우:

var args = Array.slice(arguments);
로그인 후 복사

개발자는 이러한 기술을 사용하여 다양한 요구 사항과 사용자 정의에 맞춰 기능의 매개변수와 값에 동적으로 액세스할 수 있습니다.

위 내용은 JavaScript 함수 매개변수 이름 및 값을 동적으로 검색하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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