js中typeof的用法与说明

2024-03-03 22:32
文章标签 js 用法 说明 typeof

本文主要是介绍js中typeof的用法与说明,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

typeof是一个一元运算符,返回的是字符串,对于不同的操作数,返回的结果不同。

使用

typeof是一个运算符,有2种使用方式:

  • typeof(表达式):对表达工做运算。
  • 和typeof(变量名):对变量做运算。

返回值

返回值的返回类型是字符串

  1. ‘undefined’ ----未定义的变量或值
  2. ‘boolean’ ----布尔类型的变量或值
  3. ‘string’ ----字符串类型的变量或值
  4. ‘number’ -----数字类型的变量或值
  5. ‘object’ -----对象类型的变量或值,或者null(js遗留问题,将null作为object类型处理)
  6. ‘function’ ----函数类型的变量或值
  7. ’symbol’ -----ES6提供的新的类型

举例子

typeof语法中的圆括号是可选项,如 typeof 123 等同于 typeof(123)。
typeof运算符把数组,对象或者null返回object。

//Numbers
typeof 12; //'number'
typeof 2.12; //number'
typeof(212);//'number'
typeof Math.LN2;//'number'   Math.LN2属性表示2的自然对数 Math.LN2=ln(2);约为0.693;
typeof Infinity;//'number'  Infinity不是常量,该属性是用于存放表示正无穷大的数值。如:var t1=1.25688745852369E+1023589;console.log(t1)//Infinity
typeof NaN;//'number'
typeof Number(212);//212//Strings
typeof '';//'string'
typeof 'hello';//'string'
typeof '123' ;// 'string'
typeof (typeof 1) ;//'string'  typeof 1返回的是字符串'number' typeof('number')==='string'
typeof string(123);//'123'//Booleans
typeof true;//'boolean'
typeof false;//'boolean'
typeof Boolean(true);//'boolean'//Undefined
typeof undefined;//'undefined'
typeof aaa;//'undefined'  
var aaa;typeof aaa;//'undefined';//在js中,没有值的变量,其值是undefined.typeof也返回undefined.
var aaa='';typeof aaa;//'string'; 空值与undefined不一样。空的字符串既有值也有类型。//Symbols
typeof Symbol();//'symbol'
typeof Symbol('foo');//'symbol'
typeof Symbol.iterator;//'symbol'//Objects
typeof {a:1};//'boject'
typeof [1,2,3];//'object'  typeof运算符对数组返回'object',因为是js中数组属于对象
typeof new Date();//'object'
typeof null;//'object'
typeof new Boolean(true);//'object'
typeof new Number(1);//'object'
typeof new String('abc')'//'object'
typeof /a/;//'object'
var aaa=null; typeof aaa //'object' //Functions
typeof function(){};//'function'
typeof class c {};//'function'
typeof Math.sin;//'function'

注意

我们在平时使用中,判断一个变量是否存在,经常会用if()来判断。比如:

  • 判断一个变量是否存在: if(a){}; 如果a不存在/或者a未声明,则会出错。工作台会出现 Uncaught ReferenceError:a is not defined;
  • 判断一个对象是否存在:var list={ name:‘sxx’ };如果是一个对象。if(storeList.name){} 工作台会出现 storeList is not defined;if(storeList != ‘undefiend’){} 也会提示storeList is not defined; 正确用法 if(typeof storeList !=‘undefined’){} 就不会出错了。
  • 对于Array,Null等特殊对象使用typeof一律返回object,这是typeof的局限性。
  • 判断一个对象是否是数组:instanceof用于判断一上变量是否某个对象的实例,如var a=new Array();console.log(a instanceof Array) ,返回true;console.log(a instanceof Object)也返回true;这是因为Array是Object的子类。a instanceof Object返回true并不是因为Array是Object的子对象,而是因为Array的prototype属性构造于object,Array的父级是Function。

这篇关于js中typeof的用法与说明的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/771121

相关文章

全面掌握 SQL 中的 DATEDIFF函数及用法最佳实践

《全面掌握SQL中的DATEDIFF函数及用法最佳实践》本文解析DATEDIFF在不同数据库中的差异,强调其边界计算原理,探讨应用场景及陷阱,推荐根据需求选择TIMESTAMPDIFF或inte... 目录1. 核心概念:DATEDIFF 究竟在计算什么?2. 主流数据库中的 DATEDIFF 实现2.1

MySQL中的LENGTH()函数用法详解与实例分析

《MySQL中的LENGTH()函数用法详解与实例分析》MySQLLENGTH()函数用于计算字符串的字节长度,区别于CHAR_LENGTH()的字符长度,适用于多字节字符集(如UTF-8)的数据验证... 目录1. LENGTH()函数的基本语法2. LENGTH()函数的返回值2.1 示例1:计算字符串

zookeeper端口说明及介绍

《zookeeper端口说明及介绍》:本文主要介绍zookeeper端口说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、zookeeper有三个端口(可以修改)aVNMqvZ二、3个端口的作用三、部署时注意总China编程结一、zookeeper有三个端口(可以

Java中的数组与集合基本用法详解

《Java中的数组与集合基本用法详解》本文介绍了Java数组和集合框架的基础知识,数组部分涵盖了一维、二维及多维数组的声明、初始化、访问与遍历方法,以及Arrays类的常用操作,对Java数组与集合相... 目录一、Java数组基础1.1 数组结构概述1.2 一维数组1.2.1 声明与初始化1.2.2 访问

Go语言中make和new的区别及说明

《Go语言中make和new的区别及说明》:本文主要介绍Go语言中make和new的区别及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1 概述2 new 函数2.1 功能2.2 语法2.3 初始化案例3 make 函数3.1 功能3.2 语法3.3 初始化

MySQL 中的 CAST 函数详解及常见用法

《MySQL中的CAST函数详解及常见用法》CAST函数是MySQL中用于数据类型转换的重要函数,它允许你将一个值从一种数据类型转换为另一种数据类型,本文给大家介绍MySQL中的CAST... 目录mysql 中的 CAST 函数详解一、基本语法二、支持的数据类型三、常见用法示例1. 字符串转数字2. 数字

Python中你不知道的gzip高级用法分享

《Python中你不知道的gzip高级用法分享》在当今大数据时代,数据存储和传输成本已成为每个开发者必须考虑的问题,Python内置的gzip模块提供了一种简单高效的解决方案,下面小编就来和大家详细讲... 目录前言:为什么数据压缩如此重要1. gzip 模块基础介绍2. 基本压缩与解压缩操作2.1 压缩文

java中新生代和老生代的关系说明

《java中新生代和老生代的关系说明》:本文主要介绍java中新生代和老生代的关系说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、内存区域划分新生代老年代二、对象生命周期与晋升流程三、新生代与老年代的协作机制1. 跨代引用处理2. 动态年龄判定3. 空间分

解读GC日志中的各项指标用法

《解读GC日志中的各项指标用法》:本文主要介绍GC日志中的各项指标用法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、基础 GC 日志格式(以 G1 为例)1. Minor GC 日志2. Full GC 日志二、关键指标解析1. GC 类型与触发原因2. 堆

MySQL数据库中ENUM的用法是什么详解

《MySQL数据库中ENUM的用法是什么详解》ENUM是一个字符串对象,用于指定一组预定义的值,并可在创建表时使用,下面:本文主要介绍MySQL数据库中ENUM的用法是什么的相关资料,文中通过代码... 目录mysql 中 ENUM 的用法一、ENUM 的定义与语法二、ENUM 的特点三、ENUM 的用法1