JavaScript面向对象
博客专区 > 青慕 的博客 > 博客详情
JavaScript面向对象
青慕 发表于4个月前
JavaScript面向对象
  • 发表于 4个月前
  • 阅读 0
  • 收藏 0
  • 点赞 0
  • 评论 0

标题:腾讯云 新注册用户域名抢购1元起>>>   

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
博文 14
码字总数 6563
×
青慕
如果觉得我的文章对您有用,请随意打赏。您的支持将鼓励我继续创作!
* 金额(元)
¥1 ¥5 ¥10 ¥20 其他金额
打赏人
留言
* 支付类型
微信扫码支付
打赏金额:
已支付成功
打赏金额: