javascript 中 万物皆对象。
从形式上来定义 JavaScript 的对象,是一种属性的集合。【 属性值可以是 函数(function)】
使用 对象字面量  创建对象 1 2 3 4 5 6 7 var  person = {  name : 'mcdowell' ,   age : 29 , } person.sayName  = function  (   alert (this .name ) } 
使用{}创建对象,等同于 new Object();
使用 new 借助 Object 函数  创建对象 1 2 3 4 5 6 var  person = new  Object ()person.name  = 'mcdowell'  person.age  = 29  person.sayName  = function  (   alert (this .name ) } 
问题:1.代码冗余; 2.对象中的方法不能共享,每个对象中的方法都是独立的
使用 工厂模式  创建对象 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 function  createPerson (name, age ) {  var  person = new  Object ()   person.name  = name   person.age  = age   person.sayName  = function  (     alert (this .name )   }   return  person } var  p1 = createPerson ('mcdowell' , 29 )var  p2 = createPerson ('bart' , 31 )console .log (p1, 'p1,p2' , p2)console .log (p1.constructor  === p2.constructor ) console .log (p1.constructor  === createPerson) console .log (p1 instanceof  Object ) console .log (p2 instanceof  Object ) console .log (p1.sayName  === p2.sayName ) 
工厂函数每执行一次,都会创建一个对象。各自独立的方法和属性 。
优点:避免部分代码重复,减少冗余
通过构造函数 创建对象 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 function  Person (name, age ) {  this .name  = name   this .age  = age   this .sayName  = function  (     alert (this .name )   } } var  p1 = new  Person ('mcdowell' , 29 )var  p2 = new  Person ('bart' , 31 )console .log (p1, 'p1,p2' , p2)console .log (p1.constructor  === p2.constructor ) console .log (p1.constructor  === Person ) console .log (p1 instanceof  Object ) console .log (p2 instanceof  Object ) console .log (p1.sayName  === p2.sayName ) 
每 new 一次 构造函数,都会创建一个对象各自独立的方法和属性 。
优点:进一步优化,避免部分代码重复,减少冗余
通过 原型模式  创建对象 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 function  Person (Person .prototype name  = 'person' Person .prototype sayName  = function  (  console .log (this .name , 'name' ) } var  p1 = new  Person ()var  p2 = new  Person ()p1.sayName () console .log (p1.sayName  === p2.sayName ) console .log (Person .prototype constructor ) console .log (Person .prototype constructor  == Person ) console .log (p1.__proto__  === p2.__proto__ ) 
每 new 一次 构造函数,都会创建一个对象proto  指向 Person.prototype 对象,从而实现 属性方法共享。
优点: 真正意义实现了复用
通过 原型模式 + 构造函数  创建对象 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 function  createPerson (name, age ) {  this .name  = name   this .age  = age } createPerson.protoType .sayName  = function  (   alert (this .name ) }; var  p1 = new  createPerson ('mcdowell' , 29 )var  p2 = new  createPerson ('bart' , 31 )console .log (p1, 'p1,p2' , p2)console .log (p1.constructor  === p2.constructor ) console .log (p1.constructor  === createPerson) console .log (p1 instanceof  Object ) console .log (p2 instanceof  Object ) console .log (p1.sayName  === p2.sayName ) 
优点:每个对象 都会有自己的一份 属性的副本,但又同时共享着对方法的引用,最大限度地节省了内存。
通过 Object.create  创建对象 语法:Object.create(proto, [propertiesObject])新建对象的原型对象 ,即该参数会被赋值到目标对象(即新对象,或说是最后返回的对象)的原型上。该参数可以是 null、对象、函数的 prototype 属性Object.defineProperties  的第二个参数。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 var  object = Object .create (null ) var  p1 = Object .create (  { hair : 'black' , skin : 'yellow'  },   {     type : {       value : 'person' ,       writable : false ,       enumerable : false ,       configurable : false ,     },   } ) p1.name  = 'mcdowell'  p1.age  = '20'  console .log (p1)
与 new Object 创建方式不同;new Object 创建的对象 原型 指向的原型对象一直都存在都指向 Object 构造函数 
通过 class  创建对象 类 不会像函数一样 去进行变量提升
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 class  Person  {     type = 'human'          #study = 'true'    constructor (name, age ) {          this .name  = name     this .age  = age   }      static  description = 'person'             static  create (name, age ) {     var  person = new  Person (name, age)     console .log ('创建了一个人' , person)     return  person   }      sayName (     console .log ('说出自己的名字:' , this .name )   }   speak (     console .log ('介绍自己:' , this , '私有属性 #study' , this .#study)   } } console .log ('输出静态属性description:' , Person .description )var  p1 = Person .create ('mcdowell' , 20 )p1.sayName () p1.speak () 
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 class  Man  extends  Person  {  constructor (...props ) {               super (...props)     this .sex  = 'man'    }   sayName (     console .log ('我叫' , this .name , '我是个男的' )   } } var  man = new  Man ('bart' , 22 )man.sayName () man.speak () 
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 function  Animal (  this .name  = name } Animal .prototype speak  = function  (  console .log (this .name  + ' 发出声音' ) } class  Dog  extends  Animal  {  speak (          super .speak ()     console .log (this .name  + ' 汪汪叫' )   } } var  dog = new  Dog ('阿福' )dog.speak () 
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 var  Animal  = {  speak : function  (     console .log (this .name  + ' 发出声音' )   }, } class  Dog  {  constructor (name ) {     this .name  = name   } } Object .setPrototypeOf (Dog .prototype Animal )var  dog = new  Dog ('阿福' )dog.speak () 
首先,我肯定是需要你告诉我,什么是面向对象,面向对象有哪些特点,以及这些特点的解释。