浅谈JS中的对象

由于在学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 基本数据类型的数据是对象

你可能感兴趣的:(js)