大家都知道判断数据类型的方法有很多。我们常用的有typeof但是,这个方法有一定的局限性。
typeof null // "object" typeof [8] // "object" typeof {} // "object" typeof function(){} // "function" typeof 2 //"number" typeof "" //"string" typeof true //"boolean" typeof undefined //"undefined" typeof Symbol(2) // "symbol"
typeof 无法区分null 数组和对象,通常我们会区分判断Array和Object
有时会用instanceof 来判断是不是一个对象的实例子
[] instanceof Array // true 这种方法可以判断数组,不能区分对象 [] instanceof Object // true null instanceof Object // false 也不能区分null
下面介绍一种方法,对每一种数据类型都实用。
toString.call(function(){}) // "[object Function]" toString.call(null) //"[object Null]" toString.call([2]) "[object Array]" toString.call(undefined) //"[object Undefined]" toString.call('stjd') //"[object String]" toString.call(1) //"[object Number]" toString.call(true) //"[object Boolean]" toString.call(Symbol(3)) // "[object Symbol]" toString.call({q:8}) //"[object Object]"
再来思考, toString.call([2]) 意思就是改变方法中的this指向,指向传递进去的html" target="_blank">参数,也就是[2]。那我这样写不是更直观吗?[2].toString()。结果
[2].toString() //"2"
var obj = {a: 67} console.log(obj.toString()) // [object Array]
对比上面两个返回的值是不一样的。这是因为[2].toString()调用的是数组的toSting()方法,而不是对象的toSting()方法。Array改写了Object的toString方法。
toSting.call()实际上就是 Object.prototype.toSting.call()
console.log(Object.prototype.toString.call([33])) // [object Array]
而[2].toSting()实际上是
console.log(Array.prototype.toString.call([2])) //2
使用的过程中,可以这样封装函数
function isType(type) { return function(obj) { return {}.toString.call(obj) == "[object " + type + "]" } } var isObject = isType("Object") var isString = isType("String") var isArray = Array.isArray || isType("Array") var isFunction = isType("Function") var isUndefined = isType("Undefined")
总结
到此这篇关于toString.call()通用的判断数据类型方法的文章就介绍到这了,更多相关toString.call()判断数据类型内容请搜索小牛知识库以前的文章或继续浏览下面的相关文章希望大家以后多多支持小牛知识库!
本文向大家介绍Lua判断数据类型的方法,包括了Lua判断数据类型的方法的使用技巧和注意事项,需要的朋友参考一下 一、判断数据类型的方法 type(xxxx) 这个函数的返回值是string类型 也就是说: 二、Lua脚本语言的8种基本数据类型 1.数值(number):内部以double表示. 2.字符串(string):总是以零结尾,但可以包含任意字符(包括零),因此并不等价于C字符串,而是
本文向大家介绍写一个判断数据类型的方法相关面试题,主要包含被问及写一个判断数据类型的方法时的应答技巧和注意事项,需要的朋友参考一下
本文向大家介绍JavaScript 判断数据类型的4种方法,包括了JavaScript 判断数据类型的4种方法的使用技巧和注意事项,需要的朋友参考一下 本文提供四种方法判断js数据类型,这里记录了它们之间的差异,分别是 typeof 运算符、instanceof 运算符、constructor 属性、Object.prototype.toString 方法。 一、使用 typeof 判断数据类型
本文向大家介绍JavaScript中判断数据类型的方法总结,包括了JavaScript中判断数据类型的方法总结的使用技巧和注意事项,需要的朋友参考一下 typeof typeof用的比较多的时候,是判断某个全局变量在不在,假如某个页面定义了一个全局变量。假如你做如下判断: 解决的方法是我们如下写: 用了typeof之后,就不会报错了!这是typeof的应用之一! 此外,typeof还可以进行数据类
本文向大家介绍详解JavaScript数据类型和判断方法,包括了详解JavaScript数据类型和判断方法的使用技巧和注意事项,需要的朋友参考一下 前言 JavaScript 中目前有 7 种基本(原始primitives)数据类型 Undefined, Null,Boolean, Number, String,BigInt,Symbol,以及一种引用类型 Object,Object 中又包括 F
函数名称:判断数据类型 函数名称:判断数据类型 函数方法 bool = type(str) 参数 必填 说明 str 是 需要判断的数据 返回值 说明 bool 数据类型:"number"、"string"、"boolean"、"table"、"function"、"thread"、"userdata" 函数用例 num = 111 str = tostring(num) dialog("转换后的