JS 对象基本用法

简介: JS 对象基本用法

js对象很重要,本文将会讲到以下知识点


  1. 声明对象的两种语法
  2. 如何删除对象的属性
  3. 如何查看对象的属性
  4. 如何修改或增加对象的属性
  5. 'name' in obj和obj.hasOwnProperty('name') 的区别


声明对象的两种语法


对象的定义


  • 对象是无序的数据集合
  • 键值对的集合


写法一:简写

let obj = {
    'name' : 'dong',
    'age' : 18
}

复制代码写法二:标准写法

let obj = new Object({
    'name' : 'dong',
    'age' : '18'
})

复制代码对象里面是以键值对出现的  '属性名':'属性值'

每个key都是对象的属性名(property)

每个value都是对象的属性值

所有的属性名都是字符串,就是数字也会变成字符串

如果值不是字符串也会自动转化为字符串

let obj = {
    1: 'a',
    3.2: 'b',
    1e2: true,
    1e-2: true,
    .234: true,
    0xFF: true
}

复制代码变量也可以作为属性名,需要把变量用[]括起来,如果不括起来,会自动转化为字符串

let p1 ='name'
let obj={p1:'frank} //这样写,属性名为'p1'
let obj={[p1]:'frank'} //这样写,属性名为'name'

复制代码获取obj所有的key的方法:Object.key(obj)


解释一个名词:共有属性 : 所有对象都有的属性就叫共有属性除了我们自己定义的属性外,Js中每一个对象都有一个隐藏的属性,下图中,name是我们自己定义的属性,__proto__就是隐藏属性

微信图片_20230106150043.png

这个隐藏属性存储着共有属性组的对象的地址;由共有属性组成的对象叫做原型

也就是说隐藏属性存储着原型的地址


  • 每个对象都有原型
  • 原型里存着对象的共有属性
  • 比如obj的原型就是一一个对象
  • obj.__proto__存着 这个对象的地址
  • 这个对象里有toString/constructor/valueOf等属性
  • 对象的原型也是对象


所以对象的原型也有原型

obj ={}的原型即为所有对象的原型这个原型包含所有对象的共有属性,是对象的根

这个原型也有原型,是null


对象属性的增删改查


如何删除对象的属性

let obj={
    'name':'dong',
    'age':18
}
//删除属性方法一: delete 对象名.属性名
    delete obj.name
//删除属性方法一: delete 对象名['属性名']
delete obj['name']

当属性值为undefined时,属性还存在判断属性是否还存在的方法

'属性名' in obj  ===false 

含有属性名,但是值为undefined

  '属性名' in obj && obj.属性名  ===undefined

如何查看对象的属性

查看自身所有属性

    Object.key(obj)

查看自身属性和共有属性

  console.dir(obj)

判断一个属性是自身的还是共有的?

obj.hasOwnProperty("toString')

考点 obj.name和obj['name']一样,和obj[name]不一样

let list = ['name','age','gender']
let person = {
name:'dong', age:18, gender:'man'}
 for(let i = 0; i < list. length; i++){
let name = list[i]
console.log(???)
}

???处写什么才能把对象的所有属性打印出来

console.log(person.name)还是console.log(person[name])


答案: person[name]才能把所有属性打印出来;person.name只能打印出三个dong;经过赋值,name此时等于'name';所以person[name]===person['name'],person[name]===person['age'].


如何修改或增加对象的属性


直接赋值,当对象里有这个属性则会修改原属性值,如果没有,则会增加新属性

    obj.name='dong'
    //或者是
    obj['name']='dong'

批量赋值

 Object.assign(obj,{ age:18, gender: 'man'})

修改或增加共有属性

let obj={}
let obj2 ={} //共有toString
obj.toString='xxx' //只会在改obj自身属性
obj2.toString  //还是在原型上没有变成xxx

偏要修改或增加原型上的属性

obj.__proto__.toString='xxx' //不推荐用_proto__
Object.prototype.toString ='xxx' //般来说,不要修改原型,会引起很多问题

修改隐藏属性 不推荐使用__proto__

let obj ={name:'dong'}
let obj2 ={name:'jack'}
let common ={kind:'women'}
obj._proto__= common 
obj2.__proto__= common

推荐使用Object.create

let obj = object.create(common)
obj.name ='dong'
let obj2 = Object.create(common)
obj2.name ='jack'

如果要修改隐藏属性,最好就在创建对象的时候修改


'name' in obj和obj.hasOwnProperty('name') 的区别


'name' in obj 是判断对象里有没有这个属性

obj.hasOwnProperty('name')是判断这个属性是自己的还是共有的属性



目录
相关文章
|
3月前
|
JavaScript 前端开发
如何在 JavaScript 中使用 __proto__ 实现对象的继承?
使用`__proto__`实现对象继承时需要注意原型链的完整性和属性方法的正确继承,避免出现意外的行为和错误。同时,在现代JavaScript中,也可以使用`class`和`extends`关键字来实现更简洁和直观的继承语法,但理解基于`__proto__`的继承方式对于深入理解JavaScript的面向对象编程和原型链机制仍然具有重要意义。
|
3月前
|
Web App开发 JavaScript 前端开发
如何确保 Math 对象的方法在不同的 JavaScript 环境中具有一致的精度?
【10月更文挑战第29天】通过遵循标准和最佳实践、采用固定精度计算、进行全面的测试与验证、避免隐式类型转换以及持续关注和更新等方法,可以在很大程度上确保Math对象的方法在不同的JavaScript环境中具有一致的精度,从而提高代码的可靠性和可移植性。
|
3月前
|
JSON 前端开发 JavaScript
JavaScript中对象的数据拷贝
本文介绍了JavaScript中对象数据拷贝的问题及解决方案。作者首先解释了对象赋值时地址共享导致的值同步变化现象,随后提供了五种解决方法:手动复制、`Object.assign`、扩展运算符、`JSON.stringify`与`JSON.parse`组合以及自定义深拷贝函数。每种方法都有其适用场景和局限性,文章最后鼓励读者关注作者以获取更多前端知识分享。
40 1
JavaScript中对象的数据拷贝
|
3月前
|
JavaScript 前端开发
js中的bind,call,apply方法的区别以及用法
JavaScript中,`bind`、`call`和`apply`均可改变函数的`this`指向并传递参数。其中,`bind`返回一个新函数,不立即执行;`call`和`apply`则立即执行,且`apply`的参数以数组形式传递。三者在改变`this`指向及传参上功能相似,但在执行时机和参数传递方式上有所区别。
45 1
|
3月前
|
JavaScript 前端开发
JS中的构造函数的含义和用法
构造函数是JavaScript中用于创建新对象的特殊函数,通常首字母大写。通过`new`关键字调用构造函数,可以初始化具有相同属性和方法的对象实例,从而实现代码复用。例如,定义一个`Person`构造函数,可以通过传入不同的参数创建多个`Person`对象,每个对象都有自己的属性值。此外,构造函数还可以包含方法,使每个实例都能执行特定的操作。构造函数的静态属性仅能通过构造函数本身访问。ES6引入了`class`语法糖,简化了类的定义和实例化过程。
53 1
|
3月前
|
JavaScript 前端开发 图形学
JavaScript 中 Math 对象常用方法
【10月更文挑战第29天】JavaScript中的Math对象提供了丰富多样的数学方法,涵盖了基本数学运算、幂运算、开方、随机数生成、极值获取以及三角函数等多个方面,为各种数学相关的计算和处理提供了强大的支持,是JavaScript编程中不可或缺的一部分。
|
4月前
|
JavaScript 前端开发
js的math.max的用法
js的math.max的用法
78 6
|
4月前
|
JavaScript 前端开发
JS try catch用法:异常处理
【10月更文挑战第12天】try/catch` 是 JavaScript 中非常重要的一个特性,它可以帮助我们更好地处理程序中的异常情况,提高程序的可靠性和稳定性。
90 1
|
4月前
|
JavaScript
JS中的splice的三种用法(删除,替换,插入)
JS中的splice的三种用法(删除,替换,插入)
363 4
|
4月前
|
缓存 JavaScript 前端开发
JavaScript中数组、对象等循环遍历的常用方法介绍(二)
JavaScript中数组、对象等循环遍历的常用方法介绍(二)
71 1

热门文章

最新文章