介绍
检查类型是日常编码和技术面试中 javascript 的常见做法。
您可以在 github 上找到这篇文章中的所有代码。
原始值
在 javascript 中,除 object 之外的所有类型都定义直接在语言最低级别表示的不可变值。我们将这些类型的值称为原始值。
有 7 个原始值:
立即学习“Java免费学习笔记(深入)”;
空未定义布尔值数字bigint字符串符号
除 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 exampleconsole.log(issymbol(symbol('test'))); // => trueconsole.log(isnull(null)); // => trueconsole.log(isundefined(undefined)); // => trueconsole.log(isnumber(1)); // => trueconsole.log(isstring('')); // => trueconsole.log(isboolean(true)); // => trueconsole.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 exampleconsole.log(isarray(new array())); // => trueconsole.log(isobject(object(null))); // => trueconsole.log(isfunction(object.prototype.tostring)); // => trueconsole.log(isplainobject(object.create(null))); // => true
登录后复制
object.prototype.tostring.call()
javascript 中有多种检查类型的方法,包括:
typeof 适用于除 null 之外的所有原始类型。instanceof 确定对象是否是特定构造函数或类的实例。它不适用于原始值。
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 exampleconsole.log(getType(1)); // => numberconsole.log(getType('')); // => stringconsole.log(getType({})); // => objectconsole.log(getType(null)); // => nullconsole.log(getType(undefined)); // => undefinedconsole.log(getType(Symbol())); // => symbolconsole.log(getType(BigInt(1234567890123456789012345))); // => bigintconsole.log(getType(function () {})); // => functionconsole.log(getType(new Date())); // => dateconsole.log(getType(new Map())); // => mapconsole.log(getType(new Set())); // => set console.log(getType(new RegExp("cat", "i"))); // => regex
登录后复制
参考
javascript 数据类型和数据结构 – mdn数据类型 – javascript.info参考类型 – javascript.info伟大的前端
以上就是类型实用程序 – JavaScript 挑战的详细内容,更多请关注【创想鸟】其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。
发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2660710.html