檢查類型是日常編碼和技術面試中 JavaScript 的常見做法。
您可以在 Github 上找到這篇文章中的所有程式碼。
在 JavaScript 中,除 Object 之外的所有類型都定義直接在語言最低層級表示的不可變值。我們將這些類型的值稱為原始值。
有 7 個原始值:
除 null 之外的所有原始類型都可以透過 typeof 運算子進行測試。 typeof null 傳回“object”,因此必須使用 === 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中文網其他相關文章!