文档章节

JavaScript面向对象

青慕
 青慕
发布于 2017/09/07 17:41
字数 518
阅读 2
收藏 0

1.对象的声明:JavaScript用一个{...}表示一个对象,键值对一xxx: xxx 形式声明,用","隔开(注意:最后一个键值对不需要在末尾见","  以免在低版本的IE浏览器中报错):

var person = {
    name: "歪果仁",
    age: 18,
    sex: "男",
    height:180,
    hobby:"撩妹"
}

 

访问对象的属性是通过"."操作符来完成的,但后面跟的必须是一个有效的变量名。如果属性名包含特殊字符,就必须用''括起来(如果变量不是一个有效变量,访问这个属性也无法使用".",必须用['xxx']来访问)

var student = {
    age: 18,
    student-number: 1324520
};

student['student-number'];   // 1314520

//也可以通过这样来访问其他的属性
student['age'];   //18

所以我们在编写JavaScript代码的时候尽量使用标准的变量名,这样就可以直接通过objict.prop的形式访问一个属性了。

实际上JavaScript对象的所有属性都是字符串,不过属性对应的值可以是任意数据类型。

如果访问一个对象不存在的属性不会报错,而是返回undefined。

 

JavaScript的对象是动态类型,你可以自由的给一份对象添加或删除属性。

var wuzao = {
    name:wuzao,
}

wuzao.age;  // undefined
wuzao.age = 18;  // 新增一个age属性
wuzao.age;  // 18
delete wuzao.age;  // 删除age属性
wuzao.age;  // undefined
delete wuzao['name'];  //删除name属性
delete wuzao.height;   // 删除一个不存在的height也不会报错

 

我们要检测对象是否拥有某一属性,可以用 in 操作符

var person = {
    age: 18,
    height:175
}

'age' in person;   // true
'name' in person;   // false



// 不过要注意,如果 in 判断一个属性存在,这个属性不一定是person的,它可能是person继承得到的
'toString' in person;  // true
//因为toString 定义在object对象中,而所有的对象最终都会在原形链上指向object,所以person也拥有toString属性。



// 要判断一个属性是否是person自身拥有的,而不是继承得到的,可以用hasOwnProperty() 方法。
var person = {
    age: 18,
    height:175
}
person.hasOwnProperty('age');  // true
person.hasOwnProperty('toString');  //false

 

© 著作权归作者所有

共有 人打赏支持
上一篇: JavaScript的循环
青慕
粉丝 4
博文 15
码字总数 7496
作品 0
贵阳
程序员
私信 提问

暂无文章

《唐史原来超有趣》的读后感优秀范文3700字

《唐史原来超有趣》的读后感优秀范文3700字: 作者:花若离。我今天分享的内容《唐史原来超有趣》这本书的读后感,我将这本书看了一遍之后就束之高阁了,不过里面的内容一直在在脑海中回放,...

原创小博客
17分钟前
0
0
IC-CAD Methodology知识图谱

CAD (Computer Aided Design),计算机辅助设计,指利用计算机及其图形设备帮助设计人员进行设计工作,这个定义同样可以用来近似描述IC公司CAD工程师这个岗位的工作。 早期IC公司的CAD岗位最初...

李艳青1987
26分钟前
4
0
Eos测试框架EosFactory

EOS Factory包含一个完整的EOS测试框架,可以进行智能合约的开发和测试。由Tokenika于创建于2017年的这个基于Python的EOS测试框架可以轻松地完成智能合约的开发、部署与测试。 如果你希望马上...

汇智网教程
41分钟前
5
0
CompletableFuture get方法一直阻塞或抛出TimeoutException

问题描述 最近刚刚上线的服务突然抛出大量的TimeoutException,查询后发现是使用了CompletableFuture,并且在执行future.get(5, TimeUnit.SECONDS);时抛出了TimeoutException异常,导致接口响...

xiaolyuh
今天
4
0
dubbo 搭建与使用

官网:http://dubbo.apache.org/en-us/ 一,安装监控中心(可以不安装) admin管理控制台,monitor监控中心 下载 bubbo ops 这个是新版的,需要node.js环境,我没有就用老版的了...

小兵胖胖
今天
4
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部