javascript基本数据类型及类型检测常用方法小结


Posted in Javascript onDecember 14, 2016

本文实例讲述了javascript中的基本数据类型以及类型检测的几种方法。分享给大家供大家参考,具体如下:

1.JS中有6种基本的数据类型,JS中的所有操作都是基于这五种基本类型得到的。

(1)Object

对象类型

(2)number

数字类型

(3)String

字符串类型

(4)null

(5)underfined

(6)boolean

布尔类型:true或者为false

I)JS中的数据类型转换(非严格模式下)

“12”==12 // true 在非严格模式下,字符串可以向数字转换
true==1 // true 布尔值在等号两边会尝试转换为0或者1
“1”==true //true
null==underfined //true
new Object()==new Object() //true
NaN==NaN //false

II)JS中的数据类型转换(非严格模式下)

上述中的等号均不成立

注:特别的如果为基本类型中的string或者number,在必要的情况下,可以将string或者number转化为对象object类型,转化不是持续的。

比如:

var x=”hello” ; alert(a.length) // 5

数据类型中的隐式转化补充:

“32”+32 //转化为string
"32"-32 //转化为number

JS中的类型检测方法

(1)通过typeof来进行类型检测

我们先来看几个例子:

typeof 100 —->number

typeof “hello” ——>string

typeof true —?> boolean

typeof Number ——>function

typeof new Object()——->object

typeof Object ——->function

typeof null ——?>object

typeof underfined ——?>underfined

总结:如果右边的是基本类型,则typeof会尝试得到最基本的类型,比如number,string等等,如果是函数名,那么则返回function,这里Object,Number,String,等等都可以看成函数名,如果右边是一个基本的对象,则返回object(返回的都是小写哦)。

注:我们发现typeof null,结果返回了object,这是一个很早之前的BUG,一直沿用至今

试用范围:如果通过typeof来判断类型,适用于判定基本类型,或者判断是否为函数(function)。

2.instanceof

同样举例来说明:

[1,2] instanceof Array ——> true

“1,2” instanceof Array ——->false

总结:instanceof 会沿着原型链查找,如果左边对象的原型链上,具有右边的对象,那么会返回true,并且注意只用于判断扩展的对象类型(非number,string等)

比如:

instanceof Number —?> false
"hell"  instanceof String  ------>string

补充:instanceof的右边必须是函数,或者是构造器,如果不是则会报错,检测的是左边的对象的原型链上,是否有右边函数的prototype。

3.Object.prototype.toString

通过对象原型上的toSting方法,同样也可以判断类型,我们来举例子:

Object.prototype.toString.apply([]) ——>[object Object]

Object.prototype.toString.apply(function(){}) —->[object Function]

Object.prototype.toString.apply(Number) ——->[object Function]

Object.prototype.toString.apply(String) ——?>[object Function]

Object.prototype.toString.apply(null) ———?>[object Null]

Object.prototype.toString.apply(undefined)?>[object Undefined]

使用类型:原生对象和基本类型

此外还有

(4)constructor

(5)duck type等

更多关于JavaScript相关内容可查看本站专题:《javascript面向对象入门教程》、《JavaScript中json操作技巧总结》、《JavaScript切换特效与技巧总结》、《JavaScript查找算法技巧总结》、《JavaScript错误与调试技巧总结》、《JavaScript数据结构与算法技巧总结》、《JavaScript遍历算法与技巧总结》及《JavaScript数学运算用法总结》

希望本文所述对大家JavaScript程序设计有所帮助。

Javascript 相关文章推荐
一段好玩的JavaScript代码
Dec 01 Javascript
用js实现随机返回数组的一个元素
Aug 13 Javascript
Jquery ajax执行顺序 返回自定义错误信息(实例讲解)
Nov 06 Javascript
JS兼容浏览器的导出Excel(CSV)文件的方法
May 03 Javascript
借助JavaScript脚本判断浏览器Flash Player信息的方法
Jul 09 Javascript
JavaScript中实现Map的示例代码
Sep 09 Javascript
JavaScript+html5 canvas绘制缤纷多彩的三角形效果完整实例
Jan 26 Javascript
jQuery实现布局高宽自适应的简单实例
May 28 Javascript
AngularJS框架的ng-app指令与自动加载实现方法分析
Jan 04 Javascript
JQuery页面随滚动条动态加载效果的简单实现(推荐)
Feb 08 Javascript
Bootstrap中data-target 到底是什么
Feb 14 Javascript
微信小程序报错: thirdScriptError的错误问题
Jun 19 Javascript
用v-html解决Vue.js渲染中html标签不被解析的问题
Dec 14 #Javascript
关于BootStrap modal 在IOS9中不能弹出的解决方法(IOS 9 bootstrap modal ios 9 noticework)
Dec 14 #Javascript
实例解析angularjs的filter过滤器
Dec 14 #Javascript
微信小程序 input输入框控件详解及实例(多种示例)
Dec 14 #Javascript
javascript中对象的定义、使用以及对象和原型链操作小结
Dec 14 #Javascript
JS中使用new Date(str)创建时间对象不兼容firefox和ie的解决方法(两种)
Dec 14 #Javascript
javascript中的try catch异常捕获机制用法分析
Dec 14 #Javascript
You might like
服务器端解压缩zip的脚本
2006/12/22 PHP
php下一个阿拉伯数字转中文数字的函数
2007/07/16 PHP
php开发过程中关于继承的使用方法分享
2011/06/17 PHP
从wamp到xampp的升级之路
2015/04/08 PHP
win7系统配置php+Apache+mysql环境的方法
2015/08/21 PHP
PHP单例模式简单用法示例
2017/06/23 PHP
fancybox modal的完美解决(右上的X)
2012/10/30 Javascript
JavaScript检测浏览器cookie是否已经启动的方法
2015/02/27 Javascript
JavaScript使用setTimeout实现延迟弹出警告框的方法
2015/04/07 Javascript
基于javascript实现图片懒加载
2016/01/05 Javascript
jquery实现全选功能效果的实现代码
2016/05/05 Javascript
js方法数据验证的简单实例
2016/09/17 Javascript
js实现碰撞检测特效代码分享
2016/10/16 Javascript
js省市区级联查询(插件版&无插件版)
2017/03/21 Javascript
BootStrap 获得轮播中的索引和当前活动的焦点对象
2017/05/11 Javascript
微信小程序使用npm包的方法步骤
2019/08/13 Javascript
VUE.js实现动态设置输入框disabled属性
2019/10/28 Javascript
node.js中module模块的功能理解与用法实例分析
2020/02/14 Javascript
vue 导航锚点_点击平滑滚动,导航栏对应变化详解
2020/08/10 Javascript
vue组件中实现嵌套子组件案例
2020/08/31 Javascript
微信小程序实现点赞业务
2021/02/10 Javascript
Python的多态性实例分析
2015/07/07 Python
python 多线程实现检测服务器在线情况
2015/11/25 Python
python执行系统命令后获取返回值的几种方式集合
2018/05/12 Python
Python http接口自动化测试框架实现方法示例
2018/12/06 Python
解决Python中定时任务线程无法自动退出的问题
2019/02/18 Python
Python初学者常见错误详解
2019/07/02 Python
安踏官方商城:anta.cn
2019/12/16 全球购物
.net面试题
2015/12/22 面试题
中专毕业个人的自荐信格式
2013/09/21 职场文书
《李广射虎》教学反思
2014/04/27 职场文书
合作协议书范本
2014/10/25 职场文书
幼儿园法制宣传日活动总结
2014/11/01 职场文书
优秀教师先进材料
2014/12/16 职场文书
前台接待岗位职责范本
2015/04/03 职场文书
Python函数中apply、map、applymap的区别
2021/11/27 Python