유형 확인은 일상적인 코딩 및 기술 인터뷰에서 JavaScript의 일반적인 관행입니다.
이 게시물의 모든 코드는 Github에서 확인할 수 있습니다.
JavaScript에서 Object를 제외한 모든 유형은 언어의 가장 낮은 수준에서 직접 표현되는 불변 값을 정의합니다. 이러한 유형의 값을 원시 값이라고 합니다.
7개의 기본 값이 있습니다:
null을 제외한 모든 기본 유형은 typeof 연산자로 테스트할 수 있습니다. typeof null은 "객체"를 반환하므로 null을 테스트하려면 === null을 사용해야 합니다.
따라서 첫 번째 유형의 유틸리티 함수를 얻습니다.
function isBoolean(value) { return typeof value === 'boolean'; } function isString(value) { return typeof value === 'string'; } function isNumber(value) { return typeof value === 'number'; } function isSymbol(value) { return typeof value === 'symbol'; } function isBigInt(value) { return typeof value === 'bigint'; } function isUndefined(value) { return typeof value === 'undefined'; } function isNull(value) { return value === null; } // Usage example console.log(isSymbol(Symbol('test'))); // => true console.log(isNull(null)); // => true console.log(isUndefined(undefined)); // => true console.log(isNumber(1)); // => true console.log(isString('')); // => true console.log(isBoolean(true)); // => true console.log(isBigInt(9007199254740991n)); // => true
기본 유형이 아닌 모든 것은 JavaScript의 객체입니다. 여기에는 다음이 포함됩니다.
여기에 배열, 함수, 객체에 대한 두 번째 유틸리티 함수가 있습니다.
function isArray(value) { return Array.isArray(value); } function isFunction(value) { return typeof value === 'function'; } function isObject(value) { // for null and undefined if (value == null) { return false; } return typeof value === 'object'; } function isPlainObject(value) { // for null and undefined if (value == null) { return false; } const prototype = Object.getPrototypeOf(value); return prototype === Object.prototype || prototype === null; } // Usage example console.log(isArray(new Array())); // => true console.log(isObject(Object(null))); // => true console.log(isFunction(Object.prototype.toString)); // => true console.log(isPlainObject(Object.create(null))); // => true
JavaScript에서 유형을 확인하는 방법에는 다음을 포함하여 여러 가지가 있습니다.
Object.prototype.toString.call()은 JavaScript에서 유형을 확인하는 가장 안정적인 방법입니다.
다음을 통해 유형을 추출할 수 있습니다.
function getType(value) { const type = typeof value; if (type !== 'object') { return type; } return Object.prototype.toString .call(value) .slice(8, -1) .toLowerCase(); } // Usage example console.log(getType(1)); // => number console.log(getType('')); // => string console.log(getType({})); // => object console.log(getType(null)); // => null console.log(getType(undefined)); // => undefined console.log(getType(Symbol())); // => symbol console.log(getType(BigInt(1234567890123456789012345))); // => bigint console.log(getType(function () {})); // => function console.log(getType(new Date())); // => date console.log(getType(new Map())); // => map console.log(getType(new Set())); // => set console.log(getType(new RegExp("cat", "i"))); // => regex
위 내용은 유형 유틸리티 - JavaScript 과제의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!