js-数据类型
js中有5种数据类型:Undefined、Null、Boolean、Number和String。
还有一种复杂的数据类型Object,Object本质是一组无序的名值对组成的。
一、数据类型
1、undefinde类型
Undefined类型只有一个值,即undefined,使用var声明变量,但是未对初始化的,这个变量就是Undefined类型的,例子:
var i;
alert(i == undefined);//true
var i;与var i = undefined;这两句是等价的。
包含Undefined值的变量和未定义的变量是不一样的。
2、null类型
Null类型也只有一个值:null.null表示一个空对象的指针。
3、boolean类型
Boolean类型:只有两个字面量true和false。但是js中多有的变量都可以使用Boolean()函数转换成一个Boolean类型的值。
<script type="text/javascript">
var j;
console.log(j+":"+Boolean(j)); //false
var j=null;
console.log(j+":"+Boolean(j)); //false
j=50;
console.log(j+":"+Boolean(j)); //true
j=0;
console.log(j+":"+Boolean(j)); //false
j="0";
console.log(j+":"+Boolean(j)); //true
j="";
console.log(j+":"+Boolean(j)); //false
j="abc";
console.log(j+":"+Boolean(j)); //true
console.log("----------------------");
console.log("null=='':"+(null=='')); //false
console.log("null=='null':"+(null=='null')); //false
console.log("null==undefined:"+(null==undefined)); //true
alert(123==123);
alert(0==true); //false
alert(true=="true"); //false
alert(false==0); //true
alert(1+1==2); //true
alert(0===true); //false
alert(false===0); //false
</script>
4、Number类型
整数和浮点数。NaN:Not a Number(不是数字类型的数字类型)。这个数值用于本来要返回一个数值,但是却未能放回一个数值的情况,以防止报错。例如:1/0 返回的就是NaN。
NaN的特点:
1、任何涉及NaN的操作都会返回NaN。
2、NaN对任何值都不相等,包括自己NaN本身。
针对NaN特性,JS内置了isNaN()函数,来判断一个变量是不是一个数字。如果是数字,返回false,不全是数字,返回true
5、String类型
凡是用双引号或是单引号引起来的,都属于string类型
<script type="text/javascript"> var i; console.log(i+":"+String(i)); //undefined i=null; console.log(i+":"+String(i)); //null i=123; console.log(i+":"+String(i)); //123 i=true; console.log(i+":"+String(i)); //true </script>
二、typeof操作符
对一个变量进行推断变量的类型,可能返回以下字符串:
"undefined" 如果这个值,未定义或者为初始化
"boolean" 布尔值
"string" 字符串
"number" 数值
"object" 对象
"function" 函数
用法:typeof 95; 或者 typeof(95); 会返回"number".
<script>
var b=function str(){
var a=100;
alert(a);
};
console.log(b+":"+typeof(b));
var i=100;
console.log(i+":"+typeof(i));
i=1.2;
console.log(i+":"+typeof(i));
i=1.2345678;
console.log(i+":"+typeof(i));
i=-1.23;
console.log(i+":"+typeof(i));
i=1.2e8;
console.log(i+":"+typeof(i));
i=034;
console.log(i+":"+typeof(i));
i=0x12c;
console.log(i+":"+typeof(i));
i="123";
console.log(i+":"+typeof(i));
i=true;
console.log(i+":"+typeof(i));
i=false;
console.log(i+":"+typeof(i));
var j;
console.log(j+":"+typeof(j));
i=null;
console.log(i+":"+typeof(i));
var str="123abc";
alert(typeof(str++));
alert(str);
</script>
三、数据类型的转换:
1、强制数据类型的转换 : 你知道变量将会转换成什么数据类型
强制数据类型转换
1、Number():强制的把变量准换为数字类型
NaN:不是数字类型的数字类型 not a number
2、parseInt():强制的把变量准换为数字类型,而且会转换为整数
parseFloat():强制的把变量准换为数字类型,而且会转换为float单精度浮点型
<script type="text/javascript">
//alert(typeof(NaN));
var a;
console.log(a+":"+Number(a));
a=null;
console.log(a+":"+Number(a));
a="100";
//alert("100"+100);
console.log(a+":"+(Number(a)+100));
a="-100";
console.log(a+":"+(Number(a)+100));
a="";
console.log(a+":"+(Number(a)+100));
a=true;
console.log(a+":"+Number(a));
a=false;
console.log(a+":"+Number(a));
a="123abc";
console.log(a+":"+Number(a));
var i="123";
console.log(i+":"+parseInt(i));
var i="123.456";
console.log(i+":"+parseInt(i));
var i="123.abc";
console.log(i+":"+parseInt(i)); //Nan
var i="a123bc";
console.log(i+":"+parseInt(i));
var i="12a3bc";
console.log(i+":"+parseInt(i));
var i=0x10a;
console.log(i+":"+parseInt(i));
//强制将十六进制转换为十进制
var i=123.0;
console.log(i+":"+parseFloat(i));
</script>
2、隐式数据类型的转换 : 你不知道变量将会转换成什么数据类型,但是数据确实转换了
隐式数据类型的转换 :
变成字符串:+
变成数字:- * / %
变成数字:++ --
数字的比较、字符串的比较:> <
把右边的数据类型转换为布尔型:!
<script type="text/javascript">
var i="100";
console.log(i+100);
console.log(100-"3");
console.log(100*3);
console.log(100/3);
var i="3";
i++;
console.log(i); //自加和自减都会自动转换为number
//alert("3">2); //true
//alert("3">"2"); //true
if(Boolean(2)){
alert("aaaa");
}
</script>
js-数据类型的更多相关文章
- 由js apply与call方法想到的js数据类型(原始类型和引用类型)
原文地址:由js apply与call方法想到的js数据类型(原始类型和引用类型) js的call方法与apply方法的区别在于第二个参数的不同,他们都有2个参数,第一个为对象(即需要用对象a继承b, ...
- 总结的JS数据类型判定(非常全面)
用typeof 来检测数据类型 Javascript自带两套类型:基本数据类型(undefined,string,null,boolean,function,object)和对象类型. 但是如果尝试用 ...
- JavaScript学习10 JS数据类型、强制类型转换和对象属性
JavaScript学习10 JS数据类型.强制类型转换和对象属性 JavaScript数据类型 JavaScript中有五种原始数据类型:Undefined.Null.Boolean.Number以 ...
- JS数据类型的理解(猜测)
Js 数据类型 对于这个主题,首先来看几个问题,如果你对这几个问题很清楚的话,那就请直接跳过吧,不用接着往下看了,如果不清楚,建议你还是看看. 1)如果判断函数?function 和object的联系 ...
- web开发与设计--js数据类型,js运营商
1. js数据类型划分:号码值类型,布尔,串 由typeof能够看到什么类型的数据被详述. 举例: <span style="font-family:Microsoft YaHei;f ...
- [妙味JS基础]第四课:JS数据类型、类型转换
知识点总结 JS数据类型:number数字(NaN).string字符串.boolean布尔值.函数类型.object对象(obj.[].{}.null).undefined未定义 typeof 用来 ...
- JavaScript大厦之地基:js数据类型
一.数据和类型 俗话说物以类聚,人以群分:这里将人和物都按类别进行了区分.我们数据也一样,使用计算机我们能处理数值,也可以处理文本还可以处理图形.音频.视频等各种各样的数据,不同的数据有 ...
- JS 数据类型、赋值、深拷贝和浅拷贝
js 数据类型 六种 基本数据类型: Boolean. 布尔值,true 和 false. null. 一个表明 null 值的特殊关键字. JavaScript 是大小写敏感的,因此 null 与 ...
- 1. js数据类型_对象_函数_内存
1. js数据类型有哪些? 基本(值)类型 Number ---- 任意数值 String ---- 任意字符串 Boolean ---- true/false undefined ---- unde ...
- js数据类型隐式转换问题
js数据类型隐式转换 ![] == false //true 空数组和基本类型转换,会先[].toString() 再继续比较 ![] == [] //true ![] //false [] == [ ...
随机推荐
- mycat服务启动{管理模块启动过程}
mycat启动的时候启动了三个模块 1:NIOConnector(负责链接mysql数据库,连接池以数据库为准不以链接字符串为准), 1:NIOAcceptor,ManagerConnectionFa ...
- S7-200系列PLC与WINCC以太网通信CP243i的实例
S7-200系列PLC与WINCC以太网通信CP243i的实例 ----选用大连德嘉国际电子www.dl-winbest.cn的CP243i作为连接S7-200的PPI口转以太网RJ45的接口转换器. ...
- js判断密码强度
html代码: <form name="form1" action=""> 密码:<input type="password&quo ...
- 网页内容导出word/excel的js代码
IE设置: 工具-> Internet选项-> 安全->自定义级别-> 对没有标记安全级别的ActiveX控件进行初始化 设为启用! 1.导出word //指定区域导出到Wo ...
- Linux查看端口、进程情况及kill进程
看端口: ps -aux | grep tomcat 发现并没有8080端口的Tomcat进程. 使用命令:netstat –apn 查看所有的进程和端口使用情况.发现下面的进程列表,其中最后一栏是P ...
- 使用pathogen管理Vim插件并托管到Github
参照文章[1][2]的办法,将vim打造成一个Python开发环境.文章中使用的是 pathogen + git 来管理 Vim 插件的.对这种方式还不太明白的同学可以参考[3]中的介绍.pathog ...
- Windows 8.1 Enterprise 下 安装 Eclipse 官方中文包后无法输入任何内容
最新文章:Virson's Blog 官方下载的Eclipse解压后运行,然后通过repository方式安装了中文语言包,按提示后重启,重启后不能进行任何输入,解决该问题的方法就是将eclipse. ...
- 刨根问底U3D---从Profile中窥探Unity的内存管理
这篇文章包含哪些内容 这篇文章从Unity的Profile组件入手,来探讨一下Unity在开发环境和正式环境中的内存使用发面的一些区别, 并且给出了最好控制内存的方法(我想你已经知道了...Prefa ...
- Promising Linking
Future/Promise 执行逻辑 scala Future 有几个要点,第一个是 tryAwait 需要借助 CowndownLatch 实现,第二个是可以在 Promise 挂载回调函数 首先 ...
- 介绍几个工作开发中封装的好用的android自定义控件
首先看效果图, 看下这两个界面,第一个中用到了一个自定义的FlowRadioGroup,支持复合子控件,自定义布局: 第二个界面中看到了输入的数字 自动4位分割了吧:也用到了自定义的DivisionE ...