数据类型和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. ...
随机推荐
- TDD和BDD
开发人员看测试之TDD和BDD 前言: 已经数月没有来园子了,写博客贵在坚持,一旦松懈了,断掉了,就很难再拾起来.但是每每看到自己博客里的博文的浏览量每天都在增加,都在无形当中给了我继续写博客的动 ...
- ABP之动态WebAPI
ABP之动态WebAPI ABP的动态WebApi实现了直接对服务层的调用(其实病没有跨过ApiController,只是将ApiController公共化,对于这一点的处理类似于MVC,对服务端的 ...
- oracle当需要commit
今天oracle的SQL plus 运行该删除和查询操作,然后PL/SQL还运行查询.相同的句子,结果是不一样的.我郁闷很大,然后,突然想到这可能对双方造成由数据不一致,为什么不一致呢.就是没用com ...
- C#格式化字符串中转义大括号“{}”
原文:C#格式化字符串中转义大括号"{}" 今天,用C#写程序操作Excel,读取单元格内容根据所需格式生成字符串,使用String.Format(string format,ob ...
- 查询oracle sql运行计划,一个非常重要的观点--dba_hist_sql_plan
该文章的作者给予了极大的帮助长老枯荣,为了表达我的谢意. 这适用于oracle db版本号oracle 10g或者更高的版本号. 之所以说这种看法是非常重要的,因为观点是有之一awrsqrpt报告没有 ...
- 博客测试:博客系统i94web beta1.0 申请测试
如何做了最近的博客更新,因为已经在线路和代码,我写了一个小博客系统:i94web,草草宣布beta1.0,请求您测试各种漏洞. 先看几张截图. 首页: watermark/2/text/aHR0cDo ...
- ORACLE11G RAC 施加以分离不同的实例.TAF
有套POS制 现在应用大量的,大量的数据,! 年前的交易在一定程度上的统计分析影响了额外的应用程序. 这两种应用分别OLTP和OLAP. 其实很多本项目具有的应用要求双方. 看了很多近期的其他系统, ...
- 使用SharePoint创建和定义自己的网站页面
使用SharePoint创建和定义自己的网站页面 1. 打开SharePoint Designer 2010. 2. 点击网站页面导航. 3. 在功能区点击Web部件页面,新建Employee.axp ...
- 使用ArcGIS API for Silverlight 进行复合多条件空间查询
原文:使用ArcGIS API for Silverlight 进行复合多条件空间查询 这两天帮网上认识的一个兄弟做了一个查询的示例,多多少少总结一下,在此和大家分享. 为什么说是复合多条件呢?因为进 ...
- Flex 日志管理
在Flex中调试方法有两种: 一是用trace()函数,在flex builder中进行调试: 二是用logTarget类,例如以下代码: // Create a target. var logTar ...