分享更有价值
被信任是一种快乐

如何掌握JavaScript对象

文章页正文上

这篇文章主要介绍“如何掌握JavaScript对象”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“如何掌握JavaScript对象”文章能帮助大家解决问题。JavaScript的八种数据类型,其中包括七种原始的数据类型(NumberBigIntStringBooleannullundefinedsymbol)和一种复杂类型object(也就是对象类型)。相比于原始数据类型,object之所以被称为复杂类型,是因为原始类型仅仅能表示一种数据,例如Number表示数字,String表示字符串等,而object可以通过键值对的形式,包含所有的原始数据类型。例如,我们可以使用symbol类型表示对象的ID,用String类型表示对象的名字,用Boolean表示对象的性别等等。对象中的每一个类型的数据都被称为对象的一个属性,一个对象理论上可以有无数个属性,这些属性统一在一对花括号{...}中创建。面向对象不仅仅是JavaScript的语言特性,实际上在所有的面向对象语言,如C++JavaPythonC#中都是非常重要的概念。想要学好JavaScript,必须熟练乃至精通对象的特性,因为对象渗透了JavaScript的方方面面。面向对象是一种编程思想,并非新的技术。在面向对象出世之前,程序员都是以面向过程的思想组织大量代码的。何为面向对象?这个问题在学校和面试中会被经常问到。我们可以极其高深的理解回答:万物皆对象,虽然这绝对正确,却并不是面试管或者老师想要的答案。面向对象是一种编程思想,一种组织代码的方式,是相对于面向过程而言的。在面向过程中,程序员就是上帝,上帝指挥指挥着所有的一切。例如我们常举的一个例子:把大象装进冰箱。
在面向过程中,把上帝需要先把冰箱门打开,然后把大象放进冰箱,最后把冰箱门关上。所有过程由上帝一个人操作。
在面向对象中,冰箱和大象都是存在的一个对象,而且冰箱会自己开门,大象也会自己进冰箱,然后冰箱自己把门关上即可。整个过程由上帝协调,但是具体做事的过程由对象自己完成,比如如何打开冰箱门,如何走进冰箱等。定义一个对象不需要使用关键字,直接使用花括号{..}包裹键值对就能创建对象,语法如下:以上代码就创建了一个简单的对象,并把对象赋值给了变量childchild对象拥有两个属性(两个值),一个是name,另一个是age
所谓键值对(key:value),就是简单的名称和值之间的映射。
例如上例中的name:'Tom'就是一个键值对,其中name是键,"Tom"是对应的值。实际使用过程中,可以通过键获得对应的值,就像使用变量名称获得变量值是一样的。如果一个对象中没有任何属性,那么这个对象就是一个空对象。我们可以通过简单的把{}赋值给一个变量获得空对象,还可以使用另外一种方式:一个对象创建之后,并非一成不变的,我们在使用对象的过程中,随时都可以查询对象的属性,或者更改对象。查询对象的属性值,需要使用一个新的符号:.,语法是对象名.变量名。举个简单的小李子:代码执行结果如下:在上述案例中,如果我们想查看变量child中的name属性,只需要简单的使用child.name就可以了。在一个对象变量创建完成后,我们还可以随时向变量中添加新的属性,方法如下:代码执行结果如下:
向对象变量中添加新的属性,只需要直接使用.属性名,然后直接向新属性赋值即可。如果我们此时查看变量child的内容,可以发现height属性已经位列其中了:对象的属性类型可以是任意的,我们可以直接使用child.isBoy=true向对象中添加布尔值,或者使用child.money=null添加一个值为空的属性。JavaScript对象更改属性值也非常简单,直接向变量赋值就可以了,举个简单的小李子:代码执行结果如下:可以看到,age变量已经从8变成了12。对象删除属性需要使用一个新的关键字delete,使用delet 对象名.属性名删除对象的属性:代码执行结果如下:从代码的执行结果可以看到属性age已经被删掉了。对象的属性名(键)还能够使用空格隔开的多个单词,不过在创建此类属性时需要使用双引号把键名包裹起来。举个例子:以上代码就创建了一个键名为"favorite cat"的键值对,但是在访问属性值的时候,如果使用:这种方式是错误的,引擎会把favorite当作一个键名,并在遇到cat时报错。访问此类键值,就需要方括号.可以访问普通的属性名,在例如"f免费云主机、域名avorite cat"之类的变量时可以使用[],举个例子:代码执行结果如下:方括号提供了.之外的属性访问方式,我们完全可以通过方括号代替.来操作对象的属性。例如:除了常规的属性操作之外,方括号还能通过变量访问对象属性:通过变量访问属性值的能力为我们提供了非常有用的变量访问方式,例如我们可以在程序中计算出属性的键名,然后再通过键名访问键值。举个栗子:在这里,范围属性值的key是通过计算得到的,这一功能用.是不能实现的。在创建对象时,我们还可以通过变量指定对象的键名,此类属性叫做计算属性。举个例子:代码执行结果如下:上例中的[propName]就是一个计算属性,意义也非常简单,就是使用变量propName中存储的值(此处为"name")作为对象的键名。以上的代码本质上和下面的代码作用相同:方括号中还可以使用复杂的表达式:代码执行结果如下:在实际应用中,或者匿名对象中,我们常常会使用和变量同名的属性,举个例子:这种情况下,我们就可以简写对象属性,如下:代码的执行结果:和变量命名不同,我们几乎可以使用任何值作为属性的名称,包括关键字和数字:虽然听起来不可思议,实际上,所有的关键字都可以作为对象的属性名:代码执行结果:数字也可以作为关键字的名称,如下:数字作为属性名称时,会被隐式转换为字符串,在访问属性时,不能使用.,必须使用方括号代替。在命名中,有一个小陷阱,我们不能使用__proto__作为属性的名称,这个属性是对象的一个特殊,后继会特别介绍。举个例子:JavaScript有一个需要注意的特性,即使访问一个不存的属性时也不会报错,仅仅是返回undefined
那我们如何知道,属性是否存在于对象之中呢?最简单的方式是使用if语句:这么做在大部分情况下是没有问题的,但是当属性名称的值就是undefined本身时,就会出现错误:代码执行结果:虽然prop是存在的,但是以上案例并不能正确的返回结果。这个时候就需要使用in这么做是不是优雅了许多呢?如果我们不知道对象中都存在什么属性,如何取得所有的属性值呢?
这时候就需要使用for .. in ..语句了,它类似于for循环,但是更简洁。语法举个简单的小李子:代码执行结果如下:当我们创建一个对象并遍历其中所有的属性时,属性是如何排列的呢?答案是:特别的顺序排列,并遵循以下规则:数字属性以数字顺序排列;其他属性按照创建顺序排列;数字属性在其他属性之前;举个例子:代码执行结果:关于“如何掌握JavaScript对象”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注云技术行业资讯频道,小编每天都会为大家更新不同的知识点。

相关推荐: node server.js报错如何解决

这篇文章主要介绍“node server.js报错如何解决”,在日常操作中,相信很多人在node server.js报错如何解决问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”node server.js报错如何解决”的疑惑有所帮…

文章页内容下
赞(0) 打赏
版权声明:本站采用知识共享、学习交流,不允许用于商业用途;文章由发布者自行承担一切责任,与本站无关。
文章页正文下
文章页评论上

云服务器、web空间可免费试用

宝塔面板主机、支持php,mysql等,SSL部署;安全高速企业专供99.999%稳定,另有高防主机、不限制内容等类型,具体可咨询QQ:360163164,Tel同微信:18905205712

主机选购导航云服务器试用

登录

找回密码

注册