JavaScript学习笔记(八)【对象】

在这里插入图片描述

对象

数据类型:

  • String 字符串
  • Number 数值
  • Boolean 布尔值
  • Null 空值
  • Undefined 未定义
    • 以上五种类型属于基本数据类型,只要不是以上五种,都是对象
  • Object 对象

引入:

  • 基本数据类型识单一的值,值和值之间没有任何的联系
  • 所创建的变量都是独立的,不是一个整体
  • 对象是一个复合数据类型,在对象中可以保存多个不同数据类型的属性

对象分类:

  1. 内建对象:由 ES 标准中定义的对象,在任何的 ES 的实现中都可以使用,比如 Math String Number Boolean Function Object…
  2. 宿主对象:由 JS 运行环境提供的对象,目前来说主要指由浏览器提供的对象,比如 BOM DOM
  3. 自定义对象:开发人员自己创建的对象

基本操作:

  • 使用 new 关键字调用的函数,是构造函数 construtor
  • 构造函数是专门用来创建对象的函数
  • typeof 检查,返回 object
  • 对象中保存的值称为属性
  • 语法:对象.属性名=属性值
var obj = new object();
obj.name="孙悟空";
obj.gender="男";
obj.age=18;
console.log(obj);
  • 读取对象属性: 对象.属性名
  • 读取对象中没有的属性,不会报错,会返回 undefined
  • 删除对象属性:delete 对象.属性名

属性名:

  • 属性名不强制要求遵守标识符的规范
  • 特殊属性名,用: 对象[“属性名”] = 属性值,读取也要用这种方式
  • 使用[]更加灵活,在[]中可以直接传递一个变量,这样的变量是多少就会读取那个属性

属性值:

  • 可以是任意数据类型
  • 也可以是对象嵌套
  • in 运算符,可以检查一个对象中是否有指定属性,有返回 true,没有返回 false
  • 语法:“属性名” in 对象

基本数据类型和引用数据类型

  • JS 变量保存在栈内存里,值与值独立存在
  • 对象保存在堆内存中,每创建一个新对象,就会在堆内存里开辟一个新的空间,而变量保存的是对象的内存地址(对象的引用),如果两个变量保存的是同一个对象引用,当一个通过一个变量修改属性时,另一个也会受到影响
  • 当比较两个基本数据类型的值时,就是比较值
  • 当比较两个引用数据类型时,比较对象的内存地址:如果连个对像是一模一样的,但地址不同,它也会返回 false

对象字面量

  • new object 创建对象

  • 使用对象字面量创建对象

var obj = {};
console.log(obj);

多个属性:

  • 对象字面量可以加引号也可以不加
  • 如果使用一些特殊名字,必须加引号
  • 属性名和属性值是一组一组的名值对结构,名和值之间使用冒号连接,多个名值对之间,逗号隔开,最后一个属性不加逗号
var obj2 = {
  name:"Tom",
  age = 18, 
  gender="male",
  test:{name:"John"}
};
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值