浅谈JS中的对象

本文探讨了JavaScript中的对象,包括内置对象、宿主对象和自定义对象的分类,详细解析了内置对象如Number、Date等,并阐述了宿主对象在浏览器和Node.js环境中的差异,以及自定义对象的定义。同时,介绍了全局对象global的特点,特别是window与global的关系,以及JS对象的三大定律和原型链、作用域链的概念。
摘要由CSDN通过智能技术生成

由于在学JS面向对象等高级JS的内容时感觉有点绕,所以就整理了一下JS中的对象

1、JS对象的分类

1.1 总的来说JS对象一般分为三类

a:内置对象
b:宿主对象
c:自定义对象

1.2 内置对象:分为本地对象 && 单体内置对象

本地对象:Number,Date,String ,RegExp,Map ,Set ,WeakMap ,WeakSet ,Promise, Generator ,Reflect ,Proxy, Error
这些对象可以用typeof 运算符浏览器控制台中打印出来,他们大多是function类型,Reflect的类型是object,

注意:

				 1. function 也是一种特殊的Object    	       		
			     2. 上面列出的对象都是系统提供的构造器

单体内置对象:Global对象和 Math对象

注意:单体内置对象有一个特点:不需要new,当new时,就报错了。单体内置对象,是常驻内存的,用的时候,直接用,不需要new。

1.3 宿主对象 :js代码运行的环境中提供的对象,就是宿主对象

js有两个运行环境 浏览器&& 服务器(node.js)

不同的浏览器提供的宿主对象可能不也不一样

所有的 BOM 和 DOM 对象都是宿主对象

BOM对象:

  1. window
  1. location
  2. navigator
  3. screen
  4. history

DOM 对象:

  1. Document
  1. Body
  2. Event
  3. Form
  4. Image
  5. 事件对象 event

1.4自定义对象:自己定义的对象

2、global对象

###2.1浅入global

1.所有的内置对象都是global对象的属性
2.所有在全局作用域中定义的属性和函数,都是Global对象的属性。
3.在浏览器环境中,它是不可访问的。在浏览器,它安排window对象去实现它的功能

注意:
1.在使用的过程中,window是可以省略的。 如:window.alert(). window.setInteral()…
2.在服务器端,这个golbal是真实存在的

2.2window 和global的关系

ECMA没有指出如何去访问Global对象。
浏览器都是将这个全局对象作为window对象的一部分来实现的。
所有在全局作用域中声明的变量和函数,都成为了window对象的属性
window是global在客户端js中的代言人。window对象>global对象。

3 JS对象深入探索

JS对象的三条定律和两条链

1.一切皆对象
2.对象由函数创建
3.对象是属性的无序集合
4.原型链 && 作用域链

3.1 一切皆对象

#####3.1.1 基本数据类型的数据是对象

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值