【JavaScript 从零开始】 原始值和对象引用、类型转换
JavaScript 中的原始值(undefined、null 、 布尔值、数值和字符串)于对象(包括数组和函数)有着根本区别。
原始值是不可更改的:任何方法都无法改变(或“突变”)一个原始值。
对于数字和布尔值来说显然如此-----改变数字的值本身就说不通,而对字符串来说就不那么明显了,
因为字符串看起来是有字符组成的数组,我们期望可以通过指定索引来修改字符串中的字符。
实际上,JavaScript是禁止这样做的。
字符串中所有的方法看上去返回了一个修改后的字符串,实际上返回的是一个新的字符串值。
例如:
var s = "hello"; //定义一个有小写字母组成的文本
s.toUpperCase(); //返回“HELLO”,但并没有改变s的值
s //=>"hello": 原来字符串的值并未改变
比较
原始值得比较是值得比较:只有在它们的值相等时它们才相等。
如果比较两个单独的字符串,当且仅当它们的长度相等且每个索引的字符都相等时,JavaScript才认为它们相等。
对象和原始值不同。首先,它们是可变的 -----它们的值是可修改的:
var o ={x:1}; //定义一个对象
o.x=2; //通过修改对象属性值来修改对象
o.y=3; //再次修改这个对象,给它增加一个新属性
var a = [1,2,3]; //数组也可修改的
a[0]=0; //修改数组的一个元素
a[3]=4; //给数组增加一个新元素
对象的比较并非值得比较:即使两个对象包含同样的属性及相同的值,它们也不是相等的。
各个索引元素完全相等的数组也不相等。
var o = {x:1}, p = {x: 1}; //具有相同属性的两个对象
o===p; //=>false : 两个单独的对象永不相等
var a= [] , b = []; //两个单独的空数组
a===b; //=>false : 两个单独的数组永不相等
注:a==b 也是false
我们通常将对象称为引用类型(reference type),以此来和JavaScript的基本类型区分开来。
依照术语的叫法,对象都是引用(reference),对象的比较均是引用的比较:当且仅当它们引用同一个基对象时,它们才相等。
var a = []; //定义一个引用空数组的变量a
var b= a; //变量b引用同一个数组
b[0]=1; //通过变量b 来修改引用的数组
a[0] //=> 1 : 变量a 也回修改
a===b //=> true : a和b引用同一个数组,因此相等
a==b //=> true : a和b引用同一个数组,因此相等
就像你刚刚看到的如上代码,将对象或数组复制给一个变量,激进是复制的引用值:对象本身并有复制一次。
如果你想得带一个对象或数组的副本,则必须显示复制对象的每一个属性或数组的每个元素。
下面这个例子通过循环完成数组的复制(深拷贝数组):
var a = ['a','b','c']; //待复制的数组
var b= []; //复制到的目标空数组
for (var i = 0; i<a.length ; i++) // 遍历a[]中的每个元素
{
b[i]=a[i] //强元素之复制到b中
}
下面是一个, 深拷贝一个方法(深拷贝对象)
function cloneObject(obj) {
var clone = {};
for(var i in obj) {
if(typeof(obj[i])=="object" && obj[i] != null)
clone[i] = cloneObject(obj[i]);
else
clone[i] = obj[i];
}
return clone;
}
//此方法用到了 递归,不清楚的请自行百度一下
//深拷贝的另外两种方法 //使用原型
function object(o) {
function F() {}
F.prototype = o;
return new F();
} var newObject = object(oldObject); //通过JSON
var newObject = JSON.parse(JSON.stringify(oldObject));
类型转换
JavaScript 中的取值类型非常灵活,我们已经从布尔值看到了这一点:
当JavaScript 期望使用一个布尔值的时候,你可以提供任意类型值,JavaScript 将根据需要自行转换类型。
一些值(真值)转换为 true,其他值(假值)转换为 false.
在其他类型中同样适用:
如果JavaScript 期望使用一个字符串,它吧给定的值将转换为字符串。
如果JavaScript 期望使用一个数字,他就把给定的值将转换为数字。(如果转换结果无意义,将返回NaN)
一些例子:
10 + " object" ; //=>"10 object": 数字10将成字符串
"7" * "4" ; //=>28 : 两个字符串均转换为数字
var n= 1- "x" ; //=>NaN : 字符串“x”无法转换为数字
n+" object" //=>“NaN object ” : NaN转换为字符串“NaN”
下表 简要说明了JavaScript 中如何进行类型转换的。

转换和相等性
由于JavaScript可以灵活的类型转换,因此其“==” 相等运算符也随相等的含义灵活多变。
例如 ,如下这些比较结果均是 true:
null == undefined //这两个值被认为相等
"0" == 0 //比较前字符串转换成数字
0 == false //比较前布尔值转换成数字
"0" == false //比较前字符串和布尔值都转换成数字
“==” 等于运算符在判断两个值是否相等时做了类型转换(之后会详解)
“===” 恒等运算符在判断两个值是否相等时并未做任何类型转换。
1、对于string,number等基础类型(原始值),==和===是有区别的 1)不同类型间比较,==之比较“转化成同一类型后的值”看“值”是否相等,===如果类型不同,其结果就是不等 2)同类型比较,直接进行“值”比较,两者结果一样 2、对于Array,Object等高级类型(对象引用),==和===是没有区别的 进行“指针地址”比较 3、基础类型(原始值)与高级类型(对象引用),==和===是有区别的 1)对于==,将高级转化为基础类型,进行“值”比较 2)因为类型不同,===结果为false
【JavaScript 从零开始】 原始值和对象引用、类型转换的更多相关文章
- 什么是JavaScript的原始值?
JavaScript的原始值是指数字.字符串.布尔值.null和undefined. JavaScript的数据类型分为两类:原始类型(primitive type)和对象类型(object type ...
- javascript原始值和对象引用
一句话来说:原始值是不可变的,而对象引用是可变的. js中的原始值(undefined.null.布尔值.数字和字符串)与对象(包括数组和函数)有着本质的区别.原始值是不可更改的,任何方法都无法更改一 ...
- JavaScript检测原始值、引用值、属性
上周写过一篇读书笔记<编写可维护的JavaScript>之编程实践,其中 第8章 避免『空比较』是博主在工作中遇坑较多的雷区,所以特此把该章节重新整理分享,希望大家不再坑队友(>﹏& ...
- 11 JavaScript Number原始值&对象&科学记数法&范围&进制转换&溢出Infinity&NaN
JavaScript Number对象 是经过封装的能处理数字值的对象 由Number()构造器创建 只有一种数字类型 可以使用也可以不使用小数点书写数字 JavaScript原始值与对象: 在Jav ...
- (复杂值vs原始值)&&内存空间 — 准确我们的JavaScript世界观(一):
写在前面 最近在读<JavaScript启示录>,这本书不是JavaScript的详尽的参考指南,但是把对象作为了解JavaScript的透镜,受益匪浅. 那么我们先来聊一下JavaScr ...
- 第三章:Javascript类型、值和变量。
计算机程序的运行需要对值(value)比如数字3.14或者文本"hello world"进行操作,在编程语言中,能够表示并操作的值的类型叫做数据类型(type),编程语言最基本的特 ...
- 复杂值vs原始值&&内存空间
写在前面 最近在读<JavaScript启示录>,这本书不是JavaScript的详尽的参考指南,但是把对象作为了解JavaScript的透镜,受益匪浅. 那么我们先来聊一下JavaScr ...
- JavaScript不可变原始值和可变的对象引用
一.JavaScript不可变原始值 JavaScript中的原始值(undefined,null,布尔值,数字和字符串)与对象(包括了数组和函数)有着根本的区别.原始值是不可变的(undefined ...
- 深入剖析JavaScript中的对象与原始值之间的转换机制
我们都知道原始值之间是可以互相转换的,但是如果对象转原始值呢? 所有的对象在布尔上下文(context)中均为 true .所以对于对象,不存在 to-boolean 转换, 只有字符串和数值转换. ...
随机推荐
- wpf 右下角弹出窗
自己写的wpf 弹出框,欢迎拍砖,动画都写在了后台代码,前台代码不太重要,用了一下iconfont,具体样式我就不贴出来了,本次主要是后台代码的动画 需要有父级窗口才可以使用. 前台代码: <W ...
- SqlAlchemy操作(三)
1.基于SQLALCHEMY建表 from sqlalchemy.ext.declarative import declarative_base from sqlalchemy import Colu ...
- 20164317《网络对抗技术》Exp4 恶意代码分析
1.实践目标 1.是监控你自己系统的运行状态,看有没有可疑的程序在运行. 2.是分析一个恶意软件,就分析Exp2或Exp3中生成后门软件:分析工具尽量使用原生指令或sysinternals,systr ...
- python 中 使用sys模块 获取运行脚本时在命令行输入的参数
在python项目的开发的过程中, 经常需要运行各种python脚本, 有时候还需要根据不同的使用情况输入不同的参数, 如果每次都去编辑一下脚本那就太麻烦,太耗费时间了, 这时就可以使用Python自 ...
- jzoj4724
DJL为了避免成为一只咸鱼,来找czgj学习Fibonacci数列. 通过czgj的谆谆教导,DJL明白了Fibonacci数列是这样定义的: F(1)=1;F(2)=1;F(n)=F(n-1)+F( ...
- (4)Oracle基础--操作表中数据
· 添加数据 <1> INSERT 语句 ① 向表中所有字段添加值 语法: INSERT INTO table_name (column1,column2...) VALUES(val ...
- 对一致性hash原理的理解
一致性hash算法解决的核心问题是,当solt数发生变化的时候能够尽量少的移动数据.该算法最早在<Consistent Hashing and Random Trees:Distributed ...
- Linux中MySQLl单实例源码编译安装
MySQL5.5以后源码安装要用cmake 1.3 安装相关包(cmake) 1.3.1 cmake软件 cd /home/Public/tools/ tar xf cmake-2.8.8.tar.g ...
- 【wireshark】抓包和文件格式支持
1. 抓包 捕获从网络适配器提取包,并将其保存到硬盘上. 访问底层网络适配器需要提升的权限,因此和底层网卡抓包的功能被封装在dumpcap中,这是Wireshark中唯一需要特权执行的程序,代码的其他 ...
- 常见无线组网分析(NB-IOT组网和Mesh组网)
NB-IOT LoRa Zigbee WIFI 蓝牙 组网方式 基于现有蜂窝组网 基于LoRa网关 基于Zigbee网关 基于无线路由器 居于蓝牙Mesh的网关 网络部署方式 节点 节点 + 网关 ...