JavaScript知识点总结(六)之JavaScript判断变量数据类型


Posted in Javascript onMay 31, 2016

最近做了一个项目,其中有关于js判断数据类型的处理,在网上搜了相关资料,并且亲自测试了各种数据类型的判断,绝对安全。下面小编把具体内容总结分享给大家,大家参考下!

一、JS中的数据类型

1.数值型(Number):包括整数、浮点数。

2.布尔型(Boolean)

3.字符串型(String)

4.对象(Object)

5.数组(Array)

6.空值(Null)

7.未定义(Undefined)

二、判断一个变量的数据类型

1.数值型(number)

比较常用的判断方法是:

function isNumber(val){
return typeof val === 'number';
}

但有些情况就不行,比如:

var a;
alert(isNumber(parseInt(a)));

这里弹出来的是true,如下图所示:

JavaScript知识点总结(六)之JavaScript判断变量数据类型

但实际上变量a是NaN,它是不能用于数值运算的。

所以上面的函数可以修改为:

function isNumber(val){
return typeof val === 'number' && isFinite(val);
}

修改了之后,弹出来的就是false,如下图所示:

JavaScript知识点总结(六)之JavaScript判断变量数据类型

顺便介绍一下JavaScript isFinite() 函数,isFinite() 函数用于检查其参数是否是无穷大,如果 number 是有限数字(或可转换为有限数字),那么返回 true。否则,如果 number 是 NaN(非数字),或者是正、负无穷大的数,则返回 false。

2.布尔型(boolean)

布尔类型的判断比较简单,可以用如下的方法进行判断:

/*
判断变量val是不是布尔类型
*/
function isBooleanType(val) {
return typeof val ==="boolean";
}

测试代码:

<script type="text/javascript">
/*
判断变量val是不是布尔类型
*/
function isBooleanType(val) {
return typeof val ==="boolean";
}
var a;
var b = false;
alert("变量a是布尔类型的判断结果是:"+isBooleanType(a));
alert("变量b是布尔类型的判断结果是:"+isBooleanType(b));
</script>

运行结果:

JavaScript知识点总结(六)之JavaScript判断变量数据类型

3. 字符串(String)

字符串类型的判断比较简单,可以用如下的方法进行判断:

/*
判断变量是不是字符串类型
*/
function isStringType(val) {
return typeof val === "string";
}

测试代码:

<script type="text/javascript">
/*
判断变量是不是字符串类型
*/
function isStringType(val) {
return typeof val === "string";
}
var a;
var s = "strType";
alert("变量a是字符串类型的判断结果是:"+isStringType(a));
alert("变量s是字符串类型的判断结果是:"+isStringType(s));
</script>

运行结果:

JavaScript知识点总结(六)之JavaScript判断变量数据类型

4.未定义(Undefined)

未定义的判断比较简单,可以用如下的方法进行判断:

/*
判断变量是不是Undefined
*/
function isUndefined(val) {
return typeof val === "undefined";
}

测试代码:

<script type="text/javascript">
var a;//a是undefined
var s = "strType";
/*
判断变量是不是Undefined
*/
function isUndefined(val) {
return typeof val === "undefined";
}
alert("变量a是Undefined的判断结果是:"+isUndefined(a));
alert("变量s是Undefined的判断结果是:"+isUndefined(s));
</script>

运行结果:

JavaScript知识点总结(六)之JavaScript判断变量数据类型

5.对象(Object)

由于当变量是空值Null时,typeof也会返回object,所以Object不能直接用 typeof 判断。

应该这样:

function isObj(str){
if(str === null || typeof str === 'undefined'){
return false;
}
return typeof str === 'object';
}

测试代码:

<script type="text/javascript">
/*
判断变量是不是Object类型
*/
function isObj(str){
if(str === null || typeof str === 'undefined'){
return false;
}
return typeof str === 'object';
}
var a;
var b = null;
var c = "str";
var d = {};
var e = new Object();
alert("b的值是null,typeof b ==='object'的判断结果是:"+(typeof b ==='object'));
alert("变量a是Object类型的判断结果是:"+isObj(a));//false
alert("变量b是Object类型的判断结果是:"+isObj(b));//false
alert("变量c是Object类型的判断结果是:"+isObj(c));//false
alert("变量d是Object类型的判断结果是:"+isObj(d));//true
alert("变量e是Object类型的判断结果是:"+isObj(e));//true
</script>

运行结果:

JavaScript知识点总结(六)之JavaScript判断变量数据类型

6.空值(Null)

判断空值用 val === null 即可

function isNull(val){
return val === null;
}

测试代码:

/*
判断变量是不是null
*/
function isNull(val){
return val === null;
}
/*测试变量*/
var a;
var b = null;
var c = "str";
//弹出运行结果
alert("变量a是null的判断结果是:"+isNull(a));//false
alert("变量b是null类型的判断结果是:"+isNull(b));//true
alert("变量c是null类型的判断结果是:"+isNull(c));//false

运行结果:

JavaScript知识点总结(六)之JavaScript判断变量数据类型

7.数组(Array)

数组类型不可用typeof来判断。因为当变量是数组类型是,typeof会返回object。

  这里有两种方法判断数组类型:

/*判断变量arr是不是数组
方法一
*/
function isArray(arr) {
return Object.prototype.toString.apply(arr) === '[object Array]';
}
/*判断变量arr是不是数组
方法二
*/
function isArray(arr) {
if(arr === null || typeof arr === 'undefined'){
return false;
}
return arr.constructor === Array;
}

测试代码:

<script type="text/javascript">
/*判断变量arr是不是数组
方法一
*/
function isArray(arr) {
return Object.prototype.toString.apply(arr) === '[object Array]';
}
/*判断变量arr是不是数组
方法二
*/
function isArray(arr) {
if(arr === null || typeof arr === 'undefined'){
return false;
}
return arr.constructor === Array;
}
//测试变量
var a = null;
var b = "";
var c ;
var arr = [,,];
var arr = new Array();
//打印测试结果
document.write("arr变量是数组类型,typeof arr === 'object'的结果是:"+(typeof arr === 'object'));
document.write("<br/>");
document.write("------------------------------------------------------------------------------------------------");
document.write("<br/>");
document.write("使用isArray方法判断结果如下:");
document.write("<br/>");
document.write("------------------------------------------------------------------------------------------------");
document.write("<br/>");
document.write("变量a是数组类型的判断结果是:"+isArray(a));
document.write("<br/>");
document.write("变量b是数组类型的判断结果是:"+isArray(b));
document.write("<br/>");
document.write("变量c是数组类型的判断结果是:"+isArray(c));
document.write("<br/>");
document.write("变量arr是数组类型的判断结果是:"+isArray(arr));
document.write("<br/>");
document.write("变量arr是数组类型的判断结果是:"+isArray(arr));
document.write("<br/>");
document.write("------------------------------------------------------------------------------------------------");
document.write("<br/>");
document.write("使用isArray方法判断结果如下:");
document.write("<br/>");
document.write("------------------------------------------------------------------------------------------------");
document.write("<br/>");
document.write("变量a是数组类型的判断结果是:"+isArray(a));
document.write("<br/>");
document.write("变量b是数组类型的判断结果是:"+isArray(b));
document.write("<br/>");
document.write("变量c是数组类型的判断结果是:"+isArray(c));
document.write("<br/>");
document.write("变量arr是数组类型的判断结果是:"+isArray(arr));
document.write("<br/>");
document.write("变量arr是数组类型的判断结果是:"+isArray(arr));
document.write("<br/>");
</script>

运行结果:

JavaScript知识点总结(六)之JavaScript判断变量数据类型

以上内容是小编给大家介绍的JavaScript知识点总结(六)之JavaScript判断变量数据类型的相关知识,希望对大家有所帮助,如果大家想了解更多内容敬请关注三水点靠木网站!

Javascript 相关文章推荐
jQuery EasyUI API 中文文档 - PropertyGrid属性表格
Nov 18 Javascript
一个简单的瀑布流效果(主体形式自写)
May 27 Javascript
jQuery中:enabled选择器用法实例
Jan 04 Javascript
JavaScript使用RegExp进行正则匹配的方法
Jul 11 Javascript
js实现类似菜单风格的TAB选项卡效果代码
Aug 28 Javascript
jQuery Validate初步体验(二)
Dec 12 Javascript
vue-cli 脚手架基于Nightwatch的端到端测试环境的过程
Sep 30 Javascript
VUE解决微信签名及SPA微信invalid signature问题(完美处理)
Mar 29 Javascript
JavaScript常用内置对象用法分析
Jul 09 Javascript
javascript简单实现深浅拷贝过程详解
Oct 08 Javascript
vue表单中遍历表单操作按钮的显示隐藏示例
Oct 30 Javascript
详解微信小程序入门从这里出发(登录注册、开发工具、文件及结构介绍)
Jul 21 Javascript
JavaScript知识点总结(五)之Javascript中两个等于号(==)和三个等于号(===)的区别
May 31 #Javascript
JavaScript知识点总结(四)之逻辑OR运算符详解
May 31 #Javascript
JS中使用apply方法通过不同数量的参数调用函数的方法
May 31 #Javascript
jQuery解决IE6、7、8不能使用 JSON.stringify 函数的问题
May 31 #Javascript
利用jQuery实现CheckBox全选/全不选/反选的简单代码
May 31 #Javascript
TinyMCE汉化及本地上传图片功能实例详解
May 31 #Javascript
JS定时器使用,定时定点,固定时刻,循环执行详解
May 31 #Javascript
You might like
php过滤危险html代码
2008/08/18 PHP
php download.php实现代码 跳转到下载文件(response.redirect)
2009/08/26 PHP
Thinkphp的volist标签嵌套循环使用教程
2014/07/08 PHP
thinkphp区间查询、统计查询与SQL直接查询实例分析
2014/11/24 PHP
yii2使用ajax返回json的实现方法
2016/05/14 PHP
Yii2中cookie用法示例分析
2016/07/18 PHP
php结合ajax实现手机发红包的案例
2016/10/13 PHP
PHP实现简易blog的制作
2016/10/24 PHP
PHP实现网页内容html标签补全和过滤的方法小结【2种方法】
2017/04/27 PHP
PHP jpgraph库的配置及生成统计图表:折线图、柱状图、饼状图
2017/05/15 PHP
PHP实现微信小程序人脸识别刷脸登录功能
2018/05/24 PHP
浅析PHP中json_encode与json_decode的区别
2020/07/15 PHP
js 颜色选择器(兼容firefox)
2009/03/05 Javascript
JS获取农历日期具体实例
2013/11/14 Javascript
移动节点的jquery代码
2014/01/13 Javascript
实现placeholder效果的方案汇总
2015/06/11 Javascript
Boostrap实现的登录界面实例代码
2016/10/09 Javascript
jquery实现(textarea)placeholder自动换行
2016/12/22 Javascript
深入理解JavaScript 中的匿名函数((function() {})();)与变量的作用域
2018/08/28 Javascript
JS实现checkbox互斥(单选)功能示例
2019/05/04 Javascript
微信小程序与webview交互实现支付功能
2019/06/07 Javascript
Vue实现商品分类菜单数量提示功能
2019/07/26 Javascript
JavaScript 自定义html元素鼠标右键菜单功能
2019/12/02 Javascript
jquery制作的移动端购物车效果完整示例
2020/02/24 jQuery
JS实现烟花爆炸效果
2020/03/10 Javascript
[04:59]DOTA2-DPC中国联赛 正赛 Ehome vs iG 选手采访
2021/03/11 DOTA
python使用urllib2模块获取gravatar头像实例
2013/12/18 Python
Python中操作mysql的pymysql模块详解
2016/09/13 Python
Python----数据预处理代码实例
2019/03/20 Python
机关驾驶员违规检讨书
2014/09/13 职场文书
学生违反校规检讨书
2014/10/28 职场文书
2014年图书室工作总结
2014/12/09 职场文书
大学运动会加油稿
2015/07/22 职场文书
Filebeat 采集 Nginx 日志的方法
2021/03/31 Servers
python基础学习之生成器与文件系统知识总结
2021/05/25 Python
详解解Django 多对多表关系的三种创建方式
2021/08/23 Python