什么是面向对象:

对象由两部分构成:属性 和 方法;

面向对象的特点:

  • 1.封装:对于相同功能的代码,放在一个函数中,以后再用到此功能,只需要调用即可,无需再重写;避免大量冗余代码;

    专业话说:低耦合,高内聚;

  • 2.继承:子类继承父类原有的属性和方法;

    类:'Object','Function','Number','String','Array','RegExp','Date'.....

  • 3.多态:重载和重写;

    重载:在JS中不存在严格意义上的重载;但是,JS中有类似重载的功能:同一个函数,传不同的参数,实现不同的功能;

    重写:子类可以重写父类的属性和方法;

  • 4.会学到的设计模式:单例模式,工厂模式,构造函数模式,原型模式;

  • 5.单例模式:把描述同一事物的属性和方法,放在同一个命名空间下,避免了变量名冲突的问题

    命名空间:浏览器开辟了一个堆内存,给他分配的名字person1就是命名空间

    单例模式本质:普通对象;

  • 6.模块化开发:对于一个大型项目,项目组会分配给不同的工程师去开发(这些开发是同步进行的);等所 有人开发完成,合在一起,整个项目就完成了;

    • 1)单例就是简单的模块化开发;
    • 2)可以实现本模块间的相互调用:this.属性名;
    • 3)可以实现模块之间的相互调用:模块名.属性名;
  • 7.单例模式的优缺点:

    • 优点:

      • 1)可以实现模块化开发
      • 2)避免了属性名相同,以及变量名相同的冲突问题;
    • 缺点:传统的手工作业模式,开发效率低,并且造成大量冗余代码;

    解决措施:封装--工厂模式

  • 8.工厂模式的思想:

    • 1.引进一批原材料----1.var obj={}; var obj=new Object();我们自己创建一个空对象
    • 2.对原材料进行加工---2.给空对象添加一些私有的属性和方法;
    • 3.输出原材料---3.输出对象 return obj;

    工厂模式的本质:封装;

  • 9.构造函数模式:--为了自定义一个类,并且可以创建一些实例;

    实例 instanceOf 类;==》返回的是 boolean值;

    构函数模式跟工厂模式的区别:
    • 1.在调用时候

      • 构造函数 new Person();
      • 工厂模式 person();
    • 2.在函数体内的区别;

      • 构造函数:系统自动创建一个对象,等我们给对象加工完成后,系统自动输出该对象;
      • 工厂模式:手动创建对象,等我们给对象加工完成后,手动输出对象;

      缺点:对于相同的功能,却不相等;

      解决措施:prototype原型,把功能相同的代码,放在一个公共区间;

  • 10.关于构造函数:

    • 1.构造函数中放的都是私有的属性和方法;
    • 2.就是实例和类在打交道;
    • 3.在创建一个实例的时候,如果不需要传参,小括号可以省略;
    • 4.构造函数this,永远指向当前实例;
    • 5.在构造函数中,实例只跟this.xxx有关系,跟变量没有任何关系;
    • 6.构造函数中,系统默认会为我们返回一个对象;如果我们手动返回的话:
      • 1)return 基本数据类型,不会造成任何影响;实例还有他的属性和方法;
      • 2)return 引用数据类型,会影响系统返回的对象,实例就没有他以前的属性和方法了; 所,不建议手动返回对象;
  • 11.原型模式:原型 prototype

    • 1 当我们声明了一个函数(构造函数,类)的时候,天生自带了一个prototype的属性

      • 1 并且这prototype的值也是一个对象类型的
      • 2这个对象类型值也有一个天生自带的属性叫constructor并且这个性的值是函数(构造函数,类)本身
    • 2 这个类的实例也会有一个叫做__proto__的天生自带的属性,并且这个属性的值也是一个对象类型的这个值是这个实例所属类的原型.
    • 3 每一个引用类型都有一个天生自带的属性叫__proto__,所以说我们的prototype的值也有天生自一个__proto__的属性。并且这个属性的值也是一个对象类型,一直到我们的基类Object
    • 4 通过类的原型添加的属性和方法都是公有的,每个实例都会自带
    • 5 一个实例的方法在运行的时候,如果这个方法是自己私有的,那么就直接用,如果不是私有的,那通过__proto__去所属类的原型上去查找,如果还没有就通过原型的 __proto__一直查到基类的Object.果还没有报错,如果有就直接用了。我们把这种通过__proto__查找的机制叫做原型链.
  • 12.原型模式的基础知识:重中之重

    • 1)每一个函数数据类型(类,普通函数)上都天生自带一个属性,叫做prototype(原型),它是一个对象;
    • 2)prototype这个原型上,天生自带一个属性,叫做constructor,指向当前所属的类; constructor:类;
    • 3)每个对象(实例,普通对象,prototype)上,都天生自带一个属性,叫做__proto__,他指向当前实例所属的类的原型;
  • 13.Object.prototype:都放的公有的属性和方法

    • hasOwnProperty:判断attr这属性是否是这个对象上的私有属性;
    • isPrototypeOf:obj1是否在obj2的原型链上;
    • propertyIsEnumerable:是否可枚举的属性;
  • 14

    • 每个类都是函数数据类型;
    • Object是对象数据类型的基类;
  • 15

    • 构造函数模式:实例 和 类;
    • 原型模式:实例 , 类, 原型;
    • 构造函数里:私有的属性和方法;
    • prototype上:公有的属性和方法;
  • 16.原型链查找机制:比如要查找f1.x==>对象.属性名

    • 1)在自己的私有属性上查找,如果找到那么这个属性就是私有属性;
    • 2)如果没找到,通过__proto__去所属类的原型上进行查找,因为原型上放的都是公有的属性和方法,所以,如果找到,这个属性就是公有的;
    • 3)如果没找到,通过__proto__一层层往找,最终找到基类Object.prototye上,如果还没有,undefined!
  • 17.重写:子类通过__proto__一级级往上去修改父类的属性和方法;这就是子类对父类的重写; 既然子类可以重写父类,系统为了防止子类通过__proto__去更改系统内置的属性和方法,所以在IE浏览器下,禁止我们使用__proto__;

    • 18.继承:子类可以继承父类原有的属性和方法,但是当子类添加私有属性和方法的时候,不对父类造成影响;
    • 1)原型链继承:把父类的私有+公有的属性和方法,都作为子类公有的属性; 核心:不是把父类私有+公有的属性克隆一份一模一样的给子类的公有吧;他是通过__proto__建立和子类之间的原型链,当子类的实例需要使用父类的属性和方法的时候,可以通过__proto__一级级找上去使用;
    • 2)call继承:把父类私有的属性和方法给了子类私有的属性和方法; 核心思想:相当于把父类私有的属性和方法克隆了一份一模一样的给子类的私有属性;
    • 3)冒充对象继承:把父类公有的+私有的属性都作为了子类私有的属性;
    • 4)混合继承1:call继承+原型链继承 call继承:把父类私有的作为自己私有的; 原型链继承:把父类私有+公有做为公有的; 问题:父类私有的,在子类私有+公有两个地方都存在;
    • 5)混合继承2:call继承+拷贝继承 call继承:把父类私有的作为自己私有的; 拷贝继承:通过for in循环,把父类公有的属性和方法克隆了一份一模一样的给子类公有的;
    • 6)寄生式组合继承: call继承:把父类私有的作为自己私有的;
  • Object.create()思想:

    • 1)创建一个空类;
    • 2)给空类的原型上添加了父类原型的地址;(相当于把父类原型上的公有属性和方法,给了空类原型上)
    • 3)子类的原型上添加空类的实例;(这样,子类就可以通过__proto__去找父类公有的属性和方法;但是不受父类私有属性的影响)
  • 18.继承 继承:子类可以继承父类原有的属性和方法,但是当子类添加私有属性和方法的时候,不对父类造成影响;

    • 1)原型链继承:把父类的私有+公有的属性和方法,都作为子类公有的属性; 核心:不是把父类私有+公有的属性克隆一份一模一样的给子类的公有吧;他是通过__proto__建立和子类之间的原型链,当子类的实例需要使用父类的属性和方法的时候,可以通过__proto__一级级找上去使用;
    • 2)call继承:把父类私有的属性和方法给了子类私有的属性和方法;
      • 核心思想:相当于把父类私有的属性和方法克隆了一份一模一样的给子类的私有属性;
    • 3)冒充对象继承:把父类公有的+私有的属性都作为了子类私有的属性;
    • 4)混合继承1:call继承+原型链继承
      • call继承:把父类私有的作为自己私有的;
      • 原型链继承:把父类私有+公有做为公有的;
      • 问题:父类私有的,在子类私有+公有两个地方都存在;
    • 5)混合继承2:call继承+拷贝继承
      • call继承:把父类私有的作为自己私有的;
      • 拷贝继承:通过for in循环,把父类公有的属性和方法克隆了一份一模一样的给子类公有的;
    • 6)寄生式组合继承:
      • call继承:把父类私有的作为自己私有的;
      • Object.create()思想:
        • 1)创建一个空类;
        • 2)给空类的原型上添加了父类原型的地址;(相当于把父类原型上的公有属性和方法,给了空类原型上)
        • 3)子类的原型上添加空类的实例;(这样,子类就可以通过__proto__去找父类公有的属性和方法;但是不受父类私有属性的影响)

关于JS的面向对象总结的更多相关文章

  1. JavaScript--我发现,原来你是这样的JS:面向对象编程OOP[1]--(理解对象和对象属性类型)

    一.介绍 老铁们,这次是JS的面向对象的编程OOP(虽然我没有对象,心累啊,但是可以自己创建啊,哈哈). JS高程里第六章的内容,这章内容在我看来是JS中很难理解的一部分.所以分成三篇博客来逐个理清. ...

  2. JavaScript--我发现,原来你是这样的JS:面向对象编程OOP[2]--(创建你的那个对象吧)

    一.介绍 我们继续面向对象吧,这次是面向对象编程的第二篇,主要是讲创建对象的模式,希望大家能从博客中学到东西. 时间过得很快,还是不断的学习吧,为了自己的目标. 二.创建对象 1.前面的创建对象方式 ...

  3. JS--我发现,原来你是这样的JS:面向对象编程OOP[3]--(JS继承)

    一.面向对象编程(继承) 这篇博客是面向对象编程的第三篇,JS继承.继承顾名思义,就是获取父辈的各种"财产"(属性和方法). 怎么实现继承? 我们的JavaScript比较特别了, ...

  4. JS--我发现,原来你是这样的JS:面向对象编程OOP[2]--(创建你的那个对象吧)

    一.介绍 我们继续面向对象吧,这次是面向对象编程的第二篇,主要是讲创建对象的模式,希望大家能从博客中学到东西. 时间过得很快,还是不断的学习吧,为了自己的目标. 二.创建对象 1.前面的创建对象方式 ...

  5. JavaScript基础笔记(四) JS式面向对象

    JS式面向对象 一.理解对象 一)属性类型 ECMA-262 第 5 版在定义只有内部才用的特性(attribute)时,描述了属性(property)的各种特征. ECMA-262 定义这些特性是为 ...

  6. JS--我发现,原来你是这样的JS:面向对象编程OOP[1]--(理解对象和对象属性类型)

    一.介绍 老铁们,这次是JS的面向对象的编程OOP(虽然我没有对象,心累啊,但是可以自己创建啊,哈哈). JS高程里第六章的内容,这章内容在我看来是JS中很难理解的一部分.所以分成三篇博客来逐个理清. ...

  7. 学JS的心路历程-JS支持面向对象?(一)

    昨天在看Prototype看到JS支持面向对象,被前辈问到说那什么是面向对象?JS是面向对象语言吗? 便开始了一连串艰辛爬文过程,今天就来看一下两者有什么差异吧(rgwyjc)! 首先面向对象有三大特 ...

  8. js 之面向对象

    对象 是什么? 对象就是一个整体,对外提供一些操作,比如:电视机(不用知道内部的构造,只知道怎么用) 面向对象 是什么? 使用对象时,只关注对象提供的功能,不关心内部细节,比如:操作电视机(只知道用遥 ...

  9. 探讨 JS 的面向对象中继承的那些事

    最近学了 JS 的面向对象,这篇文章主要是探讨 JS 的面向对象中继承的那些事. JS中继承的特点: 1.子类继承父类: 2.子类可以用父类的方法和属性 3.子类的改变可以不影响父类 下面用一个例子来 ...

  10. 重学前端--js是面向对象还是基于对象?

    重学前端-面向对象 跟着winter老师一起,重新认识前端的知识框架 js面向对象或基于对象编程 以前感觉这两个在本质上没有什么区别,面向对象和基于对象都是对一个抽象的对象拥有一系列的行为和状态,本质 ...

随机推荐

  1. 【Codeforces Round #459 (Div. 2) D】MADMAX

    [链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] f[x][y][z][2] 表示第一个人到了点x,第二个人到了点y,当前轮的字母(1..26),当前轮到谁走的情况下,谁赢. 写个记 ...

  2. HTTP请求具体解释

    1. HTTP请求格式 做过Socket编程的人都知道,当我们设计一个通信协议时,"消息头/消息体"的切割方式是非经常常使用的.消息头告诉对方这个消息是干什么的,消息体告诉对方怎么 ...

  3. 项目: 基于Python socket模块实现的简单 ftp 项目:

    需要 自己创建一个 info 文件 用来存储用户信息 服务器: import socket import pickle import struct import os import time ''.s ...

  4. Spark MLlib回归算法LinearRegression

    算法说明 线性回归是利用称为线性回归方程的函数对一个或多个自变量和因变量之间关系进行建模的一种回归分析方法,只有一个自变量的情况称为简单回归,大于一个自变量情况的叫做多元回归,在实际情况中大多数都是多 ...

  5. pix格式的摸索(二)

    作者:朱金灿 来源:http://blog.csdn.net/clever101 PCI的系统格式pix是一个设计很巧妙的遥感图像格式,而且其设计巧妙之处不止一处两处,这些都有待我日后一一去摸索.今天 ...

  6. web api 特点

    webapi有很多特点(我不想用优点这个词),比如说restful,支持路由,简单,类似mvc controller/action的代码编写方式,灵活的托管方式,和web的集成等等. Web API的 ...

  7. ActionListener三种实现

    /** * Simple1.java - 处理事件的第一种方法 * 在这个例子中,利用一个ActionListener来监听事件源产生的事件 * 用一些if语句来决定是哪个事件源 */ import ...

  8. Kinect 开发 —— 图片浏览

    总体思路 首先运用WPF编写一个简单的支持多点触控的图片浏览程序,这方面您可以参看MSDN上的这篇文章,上面有代码,可能需要FQ才能下载.中文的话,您可以参考Gnie同学关于在WPF上面多点触屏(Mu ...

  9. 顶级、块级、内联,html元素的三大分类

    学习html后, 你会了解一些基本的html元素(Element), 如p, h1~h6, br, div, li, ul, img等.如果将这些元素细分, 又可以分别归为顶级(top-level)元 ...

  10. C++异常实现与longjmp, setjmp,栈指针EBP, Active Record

    这篇讲的不错: http://blog.csdn.net/smstong/article/details/50728022 首先Active Record 然后EBP,ESP等指针 2 通过setjm ...