扫二维码与项目经理沟通
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流
这篇文章主要介绍“JavaScript基本类型简单赋值和对象的引用”,在日常操作中,相信很多人在JavaScript基本类型简单赋值和对象的引用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”JavaScript基本类型简单赋值和对象的引用”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!
目前成都创新互联公司已为千余家的企业提供了网站建设、域名、虚拟空间、绵阳服务器托管、企业网站设计、揭西网站维护等服务,公司将坚持客户导向、应用为本的策略,正道将秉承"和谐、参与、激情"的文化,与客户和合作伙伴齐心协力一起成长,共同发展。任何方法都无法改变一个基本类型的值,比如一个字符串:
varname='jozo';
name.toUpperCase();//输出'JOZO'
console.log(name);//输出'jozo'
会发现原始的name并未发生改变,而是调用了toUpperCase()方法后返回的是一个新的字符串。
再来看个:
varperson='jozo';
person.age=22;
person.method=function(){//...};
console.log(person.age);//undefined
console.log(person.method);//undefined
通过上面代码可知,我们不能给基本类型添加属性和方法,再次说明基本类型时不可变得;
只有在它们的值相等的时候它们才相等。
但你可能会这样:
vara=1;
varb=true;
console.log(a==b);//true
它们不是相等吗?其实这是类型转换和==运算符的知识了,也就是说在用==比较两个不同类型的变量时会进行一些类型转换。像上面的比较先会把true转换为数字1再和数字1进行比较,结果就是true了。这是当比较的两个值的类型不同的时候==运算符会进行类型转换,但是当两个值的类型相同的时候,即使是==也相当于是===。
vara='jozo';
varb='jozo';
console.log(a===b);//true
假如有以下几个基本类型的变量:
varname='jozo';
varcity='guangzhou';
varage=22;
栈区包括了变量的标识符和变量的值。
引用类型会比较好玩有趣一些。
javascript中除了上面的基本类型(number,string,boolean,null,undefined)之外就是引用类型了,也可以说是就是对象了。对象是属性和方法的集合。也就是说引用类型可以拥有属性和方法,属性又可以包含基本类型和引用类型。来看看引用类型的一些特性:
我们可为为引用类型添加属性和方法,也可以删除其属性和方法,如:
varperson={};//创建个控对象--引用类型
person.name='jozo';
person.age=22;
person.sayName=function(){console.log(person.name);}
person.sayName();//'jozo'
deleteperson.name;//删除person对象的name属性
person.sayName();//undefined
上面代码说明引用类型可以拥有属性和方法,并且是可以动态改变的。
javascript和其他语言不同,其不允许直接访问内存中的位置,也就是说不能直接操作对象的内存空间,那我们操作啥呢?实际上,是操作对象的引用,所以引用类型的值是按引用访问的。
准确地说,引用类型的存储需要内存的栈区和堆区(堆区是指内存里的堆内存)共同完成,栈区内存保存变量标识符和指向堆内存中该对象的指针,也可以说是该对象在堆内存的地址。
假如有以下几个对象:
varperson1={name:'jozo'};
varperson2={name:'xiaom'};
varperson3={name:'xiaoq'};
varperson1='{}';
varperson2='{}';
console.log(person1==person2);//true
上面讲基本类型的比较的时候提到了当两个比较值的类型相同的时候,相当于是用===,所以输出是true了。再看看:
varperson1={};
varperson2={};
console.log(person1==person2);//false
可能你已经看出破绽了,上面比较的是两个字符串,而下面比较的是两个对象,为什么长的一模一样的对象就不相等了呢?
别忘了,引用类型时按引用访问的,换句话说就是比较两个对象的堆内存中的地址是否相同,那很明显,person1和person2在堆内存中地址是不同的:
所以这两个是完全不同的对象,所以返回false;
在从一个变量向另一个变量赋值基本类型时,会在该变量上创建一个新值,然后再把该值复制到为新变量分配的位置上:
vara=10;
varb=a;
a++;
console.log(a);//11
console.log(b);//10
此时,a中保存的值为10,当使用a来初始化b时,b中保存的值也为10,但b中的10与a中的是完全独立的,该值只是a中的值的一个副本,此后,这两个变量可以参加任何操作而相互不受影响。
也就是说基本类型在赋值操作后,两个变量是相互不受影响的。
当从一个变量向另一个变量赋值引用类型的值时,同样也会将存储在变量中的对象的值复制一份放到为新变量分配的空间中。前面讲引用类型的时候提到,保存在变量中的是对象在堆内存中的地址,所以,与简单赋值不同,这个值的副本实际上是一个指针,而这个指针指向存储在堆内存的一个对象。那么赋值操作后,两个变量都保存了同一个对象地址,则这两个变量指向了同一个对象。因此,改变其中任何一个变量,都会相互影响:
vara={};//a保存了一个空对象的实例
varb=a;//a和b都指向了这个空对象
a.name='jozo';
console.log(a.name);//'jozo'
console.log(b.name);//'jozo'
b.age=22;
console.log(b.age);//22
console.log(a.age);//22
console.log(a==b);//true
因此,引用类型的赋值其实是对象保存在栈区地址指针的赋值,因此两个变量指向同一个对象,任何的操作都会相互影响。
到此,关于“JavaScript基本类型简单赋值和对象的引用”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注创新互联网站,小编会继续努力为大家带来更多实用的文章!
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流