ECMAScirpt中的数据类型:undefined、Null、Boolean、Number、String、Object

对一个值使用typeof操作符可能返回下列某个字符串:

number(数字)、function(函数)、Boolean(布尔值)、string(字符串)、object(对象或null)、undefined(未定义)

undefined类型:

在声明了变量但未对其加以初始化时,这个变量的值就是undefined

Null类型:

它的特殊值就是null,null值表示一个空对象指针

Boolean类型:

有两个字面值:true、false,注意true不一定等于1,false不一定等于0

要将一个值转换成对应的布尔值,可以调用转型函数Boolean()

Number类型

将一个值转换成对应的数字,Number()

例如:

    var a1='';
alert(Number(a1));//0 注意
var a2=true;
alert(Number(a2));//
var a3=[];
alert(Number(a3));//

parseInt、parseFloat将值转换成整数、小数

    var num=200.45;
if (parseInt(num)==parseFloat(num)) {
alert(num+'是整数');
}
else{
alert(num+'是小数');
};

Number()、parseInt()、parseFloat()都是显示类型转换,也叫强制类型转换

隐式类型转换有:

+                                                 200+’3’     变成字符串 2003

-、*、/、%

++、——                                         变成数字

>、<                                            注意数字的比较与字符串的比较是不一样的

NaN:

即not a number ,NaN不是数字的数字类型,NaN与其本身不相等,isNaN()判断某些值是不是数字;与Number相反,isNaN()是在Number转不成数字的情况下的数字类型

JavaScript:

        var oBtn=document.getElementById('btn1');
var oText=document.getElementById('text1');
var str=''; oBtn.onclick=function(){
str=oText.value;
//判断输入的内容是否为数字
if (isNaN(str)) {
alert(str+'不是数字');
}
else{
//判断是否为空格/*Number(str)==0*/
if (str==null) {
alert('输入的是空格');
}
else
{alert(str+'是数字');}
};
}

HTML:

<input id="text1" type="text">
<input id="btn1" type="button" value="判断文本框内的内容是否为数字">

数据类型转换的应用,我们来看一个例子:在输入框输入内容,要求判断:1、有没有输入 2、输入的是不是数字 3、不能有0在前面 4、不能是小数 5、输入的数字必须是在5位数以上、10位数以内

        var oBtn=document.getElementById('btn1');
var oText=document.getElementById('text1');
var str=''; oBtn.onclick=function(){
str=oText.value;
oText.value='';
if (str=='') {
alert('请输入内容');//没有输入内容
}
//判断输入的内容是否为数字
else if (isNaN(str)) {//不是数字
alert('请输入数字');//输入的不是数字
}
//判断输入的是否为空格
else if(Number(str)==0){
alert('空格无效');
}
else{//输入的是数字 //判断第一位数是否为0
if (str[0]=='0') {
alert('第一位是不能为0');
}
else{ //判断是否为小数
if (parseInt(str)==parseFloat(str)) { var num=parseInt(str);
//输入的数字必须在5位以上、10位以内
if ((num>9999)&&(num<999999999)) { alert('输入成功!');
}
else{
alert('输入的数字不在范围内');
};
}
else{
alert('输入的数字是小数'); } } };
}
 

HTML:

<input id="text1" type="text">
<input id="btn1" type="button" value="判断">
<ol>
<li>有没有输入</li>
<li>输入的是不是数字</li>
<li>不能有0在前面</li>
<li>不能是小数</li>
<li>输入的数字必须在5位以上、10位以内</li>
</ol>

注意:在输入框输入空格时,Number()能将其转换为数字0,所以,空格也是非NaN,用Number(str)==0来判断是否输入的为空格,此处本想用str==null代替却未达到效果,但在别的程序里用str==null来判断是否为空格却有用,欢迎大家前来指点!

JavaScript数据类型转换汇总的更多相关文章

  1. JavaScript数据类型转换

    原文转自:http://javascript.ruanyifeng.com/grammar/conversion.html#rd JavaScript是一种动态类型语言,变量是没有类型的,可以随时赋予 ...

  2. JavaScript 数据类型转换(显式与隐式)

    一.数据类型 JS中有5中简单数据类型(也称为基本数据类型):Undefined.Null.Boolean.Number.String.还有一种复杂数据类型------Object,Object本质是 ...

  3. (2017.10.16) javascript 数据类型转换与操作

    javascript 有 5 种基本数据类型:undefined.null.Boolean.String.Number,还有1 种较复杂的数据类型 Object:各种类型之间可以相互转换,其中有些有趣 ...

  4. JavaScript 数据类型转换表

    下表显示了将不同的JavaScript值转换为Number,String和Boolean的结果: 原始值 转换为Number 转换为String 转换为Boolean false 0 "fa ...

  5. javascript 数据类型转换

    javascrīpt 类型转换函数 在Javascrīpt中,Double类型和Int类型都是看作为Number对象. 1.Number转成String number.toString() Strin ...

  6. {}+[] = ? 和 []+{} = ? 浅谈JS数据类型转换

    参加公司技术嘉年华第一季(前端.服务端)的间隙,陈导问了我一个问题:{}+[] 和 []+{}两个表达式的值分别是什么?根据我的理解我觉得结果应该都是"[object Object]&quo ...

  7. JS中数据类型转换

    JS中数据类型转换汇总 JS中的数据类型分为 [基本数据类型] 数字 number 字符串 string 布尔 boolean 空 null 未定义 undefined [引用数据类型] 对象 obj ...

  8. JavaScript中数据类型转换总结

    JavaScript中数据类型转换总结 在js中,数据类型转换分为显式数据类型转换和隐式数据类型转换. 1, 显式数据类型转换 a:转数字: 1)Number转换: 代码: var a = " ...

  9. JavaScript的数据类型转换

    首先,由于JavaScript是弱类型语言(弱类型的语言的东西没有明显的类型,他能随着环境的不同,自动变换类型而强类型则没这样的规定,不同类型间的操作有严格定义,只有相同类型的变量才能操作,虽然系统也 ...

随机推荐

  1. atitit.md5算法的原理 与 总结

    atitit.md5算法的原理 与 总结 1. MD5的位数 128位1 2. 字节数组转换为32位字符串 base161 2.1. 十六进制字符用4个二进制位来表示1 2.2. byte[]和十六进 ...

  2. java强行删除文件(针对进程正在使用的文件的删除)

    boolean result = f.delete(); if(!result)    { System.gc(); f.delete; }

  3. Java对象的浅克隆和深克隆

    为什么需要克隆      在实际编程过程中,我们常常要遇到这种情况:有一个对象A,在某一时刻A中已经包含了一些有效值,此时可能会需要一个和A完全相同新对象B, 并且此后对B任何改动都不会影响到A中的值 ...

  4. 跟着百度学PHP[14]-PDO-优化驱动

    使用方法设置预定义变量 PDO的方法/属性 PDO::beginTransaction — Initiates a transaction PDO::commit — Commits a transa ...

  5. VC编译的时候因为加载符号导致编译过程异常缓慢的处理

    之前调试console程序用了一下Ctrl+C,弹出的异常处理选择框自己点了什么忘记了,结果之后再调试,发现特别慢,最下面一直在走着一系列dll的加载符号.让我特别二呼的是断网的话就没事了,联网就一直 ...

  6. chpasswd 更简单的更改密码的方式

    [root@m01 .ssh]# useradd test[root@m01 .ssh]# echo "test:123"|chpasswd Linux命令:chpasswd 批量 ...

  7. CI 异步验证

    $("#em").bind({ focus:function(){ var val=$(this).val(); if(val==""){ $("#e ...

  8. H.264 Profile

    提到High Profile H.264解码许多人并不了解,那么到底什么是High Profile H.264解码?其应用效果又是如何呢?  作为行业标准,H.264编码体系定义了4种不同的Profi ...

  9. 【vijos】1763 Wormhole(贪心)

    https://vijos.org/p/1764 首先第一个虫洞一定是建在1号点. 证明如下: 假设一个虫洞在a,一个在b,a<b,那么走到k点的最短距离为 min{|x1-xk|, |x1-x ...

  10. 【JavaEE】SSH+Spring Security整合及example

    到前文为止,SSH的基本框架都已经搭建出来了,现在,在这基础上再加上权限控制,也就是Spring Security框架,和前文的顺序一样,先看看需要加哪些库. 1. pom.xml Spring Se ...