关于JS的数据类型的一些见解
关于js里的数据类型这块,说下个人对它的一些见地
js中的数据类型可以归类两类,
简单数据类型:string,number,boolean,null,undefined
复杂数据类型:object
其实严格说:null是object类型
alert(10 + ":" + typeof (10));//10:number
alert("abc:" + typeof ("abc"));//abc:string
alert("true:" + typeof (true));//true:boolean
alert("null:" + typeof (null));// null:object
alert("undefined:" + typeof (undefined));//undefined:undefined
1 各数据类型的默认空值:
string:null,
number:NaN
boolean:false
null:null
undefined:undefined
object:null
var obj_str = null;//string的默认空对象
var obj_num=NaN;//number的默认空对象
var obj_bool = false;//boolean 的默认空对象
但是我们一般都是直接定义:
var obj_str, obj_num, obj_bool;
我们这样声明完了,虽然明白自己想要给他们赋予什么类型,可是为难了js了,js识别不出是什么类型的数据变量,所以 js索性丢一个undefined的默认值给他们。
所以,对于undefined我们可以理解成是:没有类型,也没有值的,说白一点儿就是在内存中根本就不给它分配位置,
undefined 也可以理解成对所有未知,不存在类型和值的对象的总称。
2.undefined和null的的区别:
我们先看一段代码:
undefined == null ? alert(true) : alert(false);
//输出:true
undefined === null ? alert(true) : alert(false);
//输出:false
他们两个本身不一样, null就相当于 一个空箱子,而undefined 就相当于什么也没有
如果转化为同一个类型(我喜欢理解成忽略类型),来比较值的话,undefined和null的值是相等的,
undefined 是空对象,null是空值。
就相当于现在去掉类型,就相当于把箱子去掉,然后 他们两个都是什么也没有了,
咱们再看另外一段代码:
undefined = 1 ? alert(true) : alert(false);
运行了这行代码,会出现什么结果?
输出结果:true
如果你感觉有些吃惊的话,那你要认真接着看了,
在说上面为什么会输出true之前,我们再看一段代码:
if (undefined = 1) {
alert(true);
}
else {
alert(false);
}
让大家失望了,我只是换了一个写法,这样能看得更明显一些:
输出true是因为 1 转化为boolean时为true,
但是,我想说的是:为什么 undefined=1 不报错呢?
原因是:undefined 虽然和 null他们归为一类,但是undefined可以赋值,
这里我参入一些我个人的看法:
undefined是js内置的空对象,这样,在给它赋值就显得理所当然了,
既然这样,null本身是一个空值,在内存中占据一格的值,那么我们如果给null赋值的话,会不会报错呢?我猜想会报错
带着这种猜想,我运行了下面的代码:
null = 1 ? alert(true) : alert(false); //报错
报错!
这也正证实了我们的猜想。
这些是我对js数据类型的一些浅显认知,望多多指教
关于JS的数据类型的一些见解的更多相关文章
- JavaScript知识 一、JS的数据类型
一.JS的数据类型 1.基本类型 JS共有5大基本类型,分别是: 1)Undefined.他只有一个值:undefined.如果一个变量被定义但是没有给他赋值,那么这个时候系统会默认给这个变量赋值为u ...
- JS中数据类型及原生对象简介
js是一种专门设计用来给网页增加交互性的编程语言,它的技术体系包含了一下几个方面: 1.JavaScript核心语言定义:包括数据类型,变量,常量,运算符,语句等. 2.原生对象和内置对象 3.浏览器 ...
- 每日学习心得:Js基本数据类型常用方法扩展
2014-02-17 前言: 节后的第一周上班,整个状态调整的还不错,已完全进入正常的工作状态.这一周主要还是对年前项目存在的一些问题进行完善.修整,基本上没有做大的改动.这里就把项目中经常用到的一些 ...
- js常用数据类型(Number,String,undefined,boolean) 引用类型( function,object,null ),其他数据类型( 数组Array,时间Date,正则RegExp ),数组与对象的使用
js常用数据类型 数字类型 | 字符串类型 | 未定义类型 | 布尔类型 typeof()函数查看变量类型 数字类型 Number var a1 = 10; var a2 = 3.66; conso ...
- JavaScript笔记1———js的数据类型
JS的数据类型有: 1.数值类型(Number):js中所有数字均用浮点数字表示. 可以表示32位(即4字节)的整数,也可以表示64位(即8字节)的浮点数(小数). 也可以用二进制.八进制.十进制.十 ...
- js 基础数据类型和引用类型 ,深浅拷贝问题,以及内存分配问题
js 深浅拷贝问题 浅拷贝一般指的是基本类型的复制 深拷贝一般指引用类型的拷贝,把引用类型的值也拷贝出来 举例 h5的sessionStorage只能存放字符串,所以要存储json时就要把json使用 ...
- js的数据类型--字符串
js的数据类型——字符串 这篇我们来说说js的第二种数据类型——字符串. js的内置功能之一就是字符串拼接.如果将加号(+)运算符用于数字,表示两数相加.但将它作用于字符串,则表示字符串拼接,将第二个 ...
- js的数据类型--数字
近期做一些项目的时候发现,自己的js基础还是不够扎实,再看一遍犀牛书,加深自己的理解和印象.所以从这篇文章开始,后面都是关于原生js的一些内容. 这篇文章,我们具体介绍一下js的数据类型其中一种. j ...
- JS基本数据类型&流程控制
JS基本数据类型 number ----- 数值 boolean ----- 布尔值 string ----- 字符串 [x,y] -------数组 undefined ...
随机推荐
- 使用 Grafana、collectd 和 InfluxDB 打造现代监控系统
想打造 New Relic 那样漂亮的实时监控系统我们只需要 InfluxDB/collectd/Grafana 这三个工具,这三个工具的关系是这样的: 采集数据(collectd)-> 存储数 ...
- oslo.messaging 1.8.0 bug fix and blueprint
1366597 由于amqp_auto_delete可配置,但是NotifierPublisher使用的是没有在配置中获取而使用的默认的False,即非auo_delete,因而在用户配置了amqp_ ...
- openstack搭建配置
安装和配置网络节点vim /etc/sysctl.confnet.ipv4.ip_forward=1net.ipv4.conf.all.rp_filter=0net.ipv4.conf.default ...
- ionic获取焦点
功能需求:点击按钮后获取input输入框的焦点 获取焦点用jq focus()不成功,因为angular也不推荐,所以网上找了一个在focus封装成指令的方法 指令写法: .directive('my ...
- Dashboard索引缺失、查询不到endpoint或counter
触发graph的索引全量更新.补救手工操作带来的异常.触发方式为,运行curl -s "http://$hostname:$port/index/updateAll",其中$hos ...
- [推荐] WordPress主题使用Google Fonts字体访问不了的解决办法
外国人做的WordPress主题喜欢带上Google的字体,但到了咱天朝是没法访问fonts.googleapis.com的 现有数字公司出的公共资源库可以替换,把fonts.googleapis.c ...
- JS小数点加减乘除运算后位数增加的解决方案
/** * 加法运算,避免数据相加小数点后产生多位数和计算精度损失. * * @param num1加数1 | num2加数2 */ function numAdd(num1, num2) { var ...
- JAVA多线程实现的三种方式
JAVA多线程实现方式主要有三种:继承Thread类.实现Runnable接口.使用ExecutorService.Callable.Future实现有返回结果的多线程.其中前两种方式线程执行完后都没 ...
- Viewdraghelper解析
2013年谷歌i/o大会上介绍了两个新的layout: SlidingPaneLayout和DrawerLayout,现在这俩个类被广泛的运用, 其实研究他们的源码你会发现这两个类都运用了ViewDr ...
- WEB三层架构与MVC
web三层架构是指: >用户接口层(UI Layer) >业务逻辑层(Bussiness Layer) >持久化层 关于业务逻辑和用户接口 在早期的web开发中,因为业务比较简单,并 ...