数据类型和typeof操作符
虽然学习js有一段时间了,但是对js的基础语法却是有些生疏。最近在看jquery源码,决定随带总结一些基础的语法知识。今天总结一下数据类型和typeof,这在写js的时候,是不得不知道的知识。
数据类型:
js有5种基本的数据类型:undefined,Null,Boolean,Number,string;和一种复杂的数据类型:object,js不支持所有自定义的数据类型,所以所有变量的值都是以上类型。
typeof:它的出现用来检测变量的数据类型,它可能的值有6种。
undefined---如果这个值未被定义(变量未声明||只声明未被初始化||声明初始化为undefined)
boolean,number,string,object,function.
undefined数据类型:这种数据类型只有一个值undefined。
//第一个例子
var m1;//只声明了,未被初始化
var m2=undefined;//声明初始化undefined
alert(m1);//undefined
alert(m2);//undefined
alert(typeof m1);//undefined
alert(typeof m2);//undefined
//第一个例子显示,变量声明之后,自动赋值undefined且数据类型为undefined //第二个例子
alert(n);//n未声明,产生错误
alert(typeof n);//undefined
//第二个例子显示,未被定义的变量值的数据类型为undefined
Null数据类型:这种数据类型也只有一个值null,null它表示一个空对象指针。在定义变量的时候,如果意在存储对象,则应该像这样var n=null;可以区分null和undefined。
var n=null;
alert(typeof n);//object
Boolean数据类型:这种数据类型只有两个值:true和false,区分大小写。虽然只有这两个值,但是所有类型的值都可以与这两个值进行转换(可以用Boolean()转型函数),这在if控制语句中非常有用。转换关系如下:
| 数据类型 | 转化为true | 转化为false |
| Boolean | true | false |
| undefined | 无 | undefined |
| object | 任何对象 | null |
| string | 任何非空字符 | 空字符 |
| number | 任何非零数字 | null和NaN |
Number数据类型:
其中比较特别的是NaN(非数值,是一个比较特殊的数值),此数值表示一个本来要返回数值的操作数未返回的情况。并且它有两个比较奇怪的特点:1.任何关于NaN的操作都会返回NaN,2.NaN与任何值都不相等,包括它本身。正因为它的这些特性,ECMAscript定义了一个函数isNaN(),通过这个函数,我们就可以对任何数据类型的值进行判断,以此来确定这些值是否是数值。在判断的之前,isNaN()函数会先对能进行转换的值进行转换(Boolean数据类型的true,false可以分别转换为1,0;字符串的数值字符串可以转换为相应的数值),而判断过程中,是数值的会返回false,不是数值的会返回true。如下
alert(isNaN("MYname"));//true
alert(isNaN(""))//false,字符串会先转换为数值
alert(isNaN(true))//false,会转换为1
alert(isNaN(NaN))//true
string数据类型:
var str1 = "myname",
str2 = ""; typeof str1 //string
typeof str2 //string
object引用类型:
var vs1 = [],
vs2 = Object; typeof vs1;// object
typeof vs2;//function
在检测引用类型的时候,情况会有点复杂,将在以后的文章中说到
数据类型和typeof操作符的更多相关文章
- js基础回顾-数据类型和typeof怎么用
js的基本数据类型有六种,undefined.null.number.string.boolean.object. 未定义 空 数字 字符串 布尔 ...
- JavaScript中数据类型和typeof返回的数据类型
除了上图,要注意三点:1.symbol是ES6中新增的数据类型 2.typeof(null)结果是Object 3.typeof(Object)和typeof(Array)的结果是function,因 ...
- js的数据类型和typeof数据类型
js的数据类型:number,string,null,undefined,Boolean,object typeof数据类型:number,string,object,function,undefin ...
- Java数据类型和MySql数据类型对应一览
类型名称 显示长度 数据库类型 JAVA类型 JDBC类型索引(int) 描述 VARCHAR L+N VARCHAR java.lang.String 12 CHAR N ...
- Sql Server中的数据类型和Mysql中的数据类型的对应关系(转)
Sql Server中的数据类型和Mysql中的数据类型的对应关系(转):https://blog.csdn.net/lilong329329/article/details/78899477 一.S ...
- SQL数据类型和C#数据类型间的转换
今天看到SQL数据类型和C#数据类型间的转换,前人留下的. <?xml version="1.0" encoding="utf-8" ?> < ...
- MySql数据类型和Java数据类型对应一览
类型名称 显示长度 数据库类型 JAVA类型 JDBC类型索引(int) 描述 VARCHAR L+N VARCHAR java.lang.String 12 CHAR N ...
- Java数据类型和MySql数据类型对应一览 [转]
类型名称 显示长度 数据库类型 JAVA类型 JDBC类型索引(int) 描述 VARCHAR L+N VARCHAR java.lang.String 12 CHAR N ...
- mysql数据类型和java数据类型匹配
Java数据类型和MySql数据类型对应一览 类型名称 显示长度 数据库类型 JAVA类型 JDBC类型索引(int) 描述 VARCHAR L+N VARCHAR java. ...
随机推荐
- js实现双击后网页自己主动跑-------Day55
公司的界面设计环节总算是告一段落了,必需要承认的是,这段时间晚间的学习带给我非常多益处.在工作中偶尔的应用,效果出奇的好,收到领导和同事的一些小赞扬,表示非常欣慰,也长了点不少自信,尽管不理解,他们这 ...
- 使用批处理文件命令行方式快速启动和停止IIS、SqlServer
原文:使用批处理文件命令行方式快速启动和停止IIS.SqlServer 虽然现在内存便宜了,但是自己还是嫌自己的512M内存太小,没办法,后台运行的东西太多了,有很多都是有用的没法关闭的.IIS和SQ ...
- hdu 3695 Computer Virus on Planet Pandora(AC自己主动机)
题目连接:hdu 3695 Computer Virus on Planet Pandora 题目大意:给定一些病毒串,要求推断说给定串中包括几个病毒串,包括反转. 解题思路:将给定的字符串展开,然后 ...
- Oracle查询速度慢的原因总结
Oracle查询速度慢的原因总结 查询速度慢的原因很多,常见如下几种:1,没有索引或者没有用到索引(这是查询慢最常见的问题,是程序设计的缺陷)2,I/O吞吐量小,形成了瓶颈效应.3,没有创建计算列导致 ...
- java基金会成立
在java在,数据收集的操作,应使用非常.最近看了零星收集的小知识,在这里,一点点排序. 它基本上是四个常用的类操作点总结集合. 首先.集合大致分为两个方向.一种是普通的集合类型,通过接口collec ...
- NYNU_省赛选拔题(7)
题目描述 In computer science, a binary tree is a tree data structure in which each node has at most two ...
- string.Format对C#字符串格式化
String.Format 方法的几种定义: String.Format (String, Object) 将指定的 String 中的格式项替换为指定的 Object 实例的值的文本等效项.Stri ...
- 【高德地图API】汇润做爱地图技术大揭秘
原文:[高德地图API]汇润做爱地图技术大揭秘 昨日收到了高德地图微信公众号的消息推送,说有[一大波免费情趣用品正在袭来],点进去看了一眼,说一个电商公司(估计是卖情趣用品的)用高德云图制作了一张可以 ...
- c/cpp中怎样切割字符串,相似于split的功能
在python中,假设要求当前时间的unix时间戳,我特别喜欢这么用: import time timestr = time.time() timestamp = int(timestr.split( ...
- mysql 数据库插入语句之insert into,replace into ,insert ignore
近期才发现mysql的插入语句竟然有如此多的使用方法,这里拿来分享一下. ①关于insert into : insert into table_name values(); insert into t ...