美文网首页
对象、原型

对象、原型

作者: 柯良勇 | 来源:发表于2016-05-25 16:53 被阅读34次

OOP 及其特性

OOP:全称 Object Oriented Programming,面向对象程序设计。传统的计算机程序是由一系列的指令和函数组成,而面向对象编程的程序是由一个个独立的代码块也就是对象组成的,一个个对象分工合作完成任务。
特性

  • 继承性:由构造函数所创建的对象会继承其创造者的一部分公共属性。
  • 多态性:由继承而产生相关的不同实例会有不同的具体功能。
  • 封装性:在一个对象的内部,某些代码是私有的不能被外界访问到的。

如何通过构造函数的方式创建一个拥有属性和方法的对象

先定义一个函数,里面用this.xx等设置相关值和函数,就是属性和方法啦,然后用new关键字创建一个对象就可以了;例如:

function People(name,age){
  this.name=name;
  this.age=age;
  this.introduce=function(){
    console.log('Hello , My name is '+this.name+' I am '+age+' years old');
  }
}
var jon = new People('jon',20);

prototype 及其特性

prototype:是原型的意思,在javascript中每个对象都有原型也就是prototype属性。这个属性存的是一个地址,指向一个原型对象。可以用这个属性来给对象添加固有属性。
特征:在原型中所拥有的特性,继承的对象都会有,因为继承的对象都会有一个proto属性指向原型。

画出如下代码的原型图

function People (name){
  this.name = name;
  this.sayName = function(){
    console.log('my name is:' + this.name);
  }
}

People.prototype.walk = function(){
  console.log(this.name + ' is walking');  
}

var p1 = new People('饥人谷');
var p2 = new People('前端');
原型图

变量name

function People (){
  var name = "饥人谷"   // 这个name 是函数内的 局部变量
  this.name = "我";      // 这个name 根据this指向不同而不同 正常运行时是window全局变量;new一个新对象时又是指代新对象的name属性
}
People.name = "jscode";  // 这个name 是People这个函数的一个属性 函数也是对象

People.prototype.name = "学前端";  // 这个name是People的原型的一个属性 这样做以后 用People构造的对象就都会继承name这个属性了,但是如果复写的话就会被覆盖。

小练习

1.创建一个 Car 对象,拥有属性name、color、status;拥有方法run,stop,getStatus

function Car(name,color,status){
  this.name=name;
  this.color=color;
  this.status=status;
  this.run=function(){
    this.status='run';
  }
  this.stop=function(){
    this.status='stop';
  }
  this.getStatus=function(){
    return this.status;
  }
}
var car = new Car('byd','white','stop'); 

2.创建一个 GoTop 对象,当 new 一个 GotTop 对象则会在页面上创建一个回到顶部的元素,点击页面滚动到顶部;拥有以下属性和方法

  • ct属性,GoTop 对应的 DOM 元素的容器
  • target属性, GoTop 对应的 DOM 元素
  • bindEvent 方法, 用于绑定事件
  • createNode 方法, 用于在容器内创建节点
<script src="http://apps.bdimg.com/libs/jquery/1.9.1/jquery.min.js"></script>
<script>
  function GoTop($ct){
    this.ct=$ct;
    this.target=$('<button>点我回到顶部</button>');
    this.creatNode=function(){
      this.ct.append(this.target);
    }
    this.bindEvent=function(){
      this.target.on('click',function(){
        $(window).scrollTop(0);
      })
    }
    this.creatNode();
    this.bindEvent();
  }
  var goTop = new GoTop($('body'));
</script>

相关文章

  • javascript中面向对象编程-创建对象之原型模式

    理解名词:对象 原型对象 原型属性 函数 构造函数 实例 对象: Object,创建对象,对象属性方法原型对象:...

  • JS重要概念之原型与原型链

    #Prototype原型对象 原型对象Function.prototype,具备以下特点:原型对象prototyp...

  • 📕 原型对象

    基本概念 原型 每一个对象都有它的原型对象,可以使用自己原型对象上的所有属性和方法 原型链 对象有原型,原型也是对...

  • 原型对象和对象原型以及原型链

    首先我们要知道,什么是原型对象,什么又是对象原型? 1.原型就是原型对象------prototype 作用就是...

  • 面向对象之原型对象和其他补充

    原型对象概念 原型对象的作用 如何访问构造函数的原型对象 ① 构造函数.protoType ② 对象.__prot...

  • JavaScript

    原型: 原型对象也是普通的对象,是对象一个自带隐式的 proto 属性,原型也有可能有自己的原型,如果一个原型对象...

  • Javascript-原型与原型链

    简单介绍 JavaScript 每个对象都拥有一个原型对象,对象以其原型为模板从原型中继承方法和属性; 原型对象也...

  • 对象初始化的不同方式

    不带原型的对象 带原型的对象

  • 原型链

    原型链函数的原型对象prototype函数都有prototype属性指向函数的原型对象【只有函数根除外】原型对象的...

  • 3.原型链、eval、Function等用法

    原型 原型本身是一个对象,这个对象的属性与方法可供其他对象。 谁有原型 默认所有的对象都有原型 谁有prototy...

网友评论

      本文标题:对象、原型

      本文链接:https://www.haomeiwen.com/subject/bfytdttx.html