面向对象

2017-09-04  本文已影响0人  Wensx

问题1: OOP 指什么?有哪些特性

OOP是指面向对象编程,它将真实世界各种复杂的关系,抽象为一个个对象,然后由对象之间的分工与合作,完成对真实世界的模拟。
那么,“对象”(object)到底是什么?
我们从两个层次来理解。
(1)对象是单个实物的抽象。
一本书、一辆汽车、一个人都可以是对象,一个数据库、一张网页、一个与远程服务器的连接也可以是对象。当实物被抽象成对象,实物之间的关系就变成了对象之间的关系,从而就可以模拟现实情况,针对对象进行编程。
(2)对象是一个容器,封装了属性(property)和方法(method)。
属性是对象的状态,方法是对象的行为(完成某种任务)。比如,我们可以把动物抽象为animal对象,使用“属性”记录具体是那一种动物,使用“方法”表示动物的某种行为(奔跑、捕猎、休息等等)。

有封装、多态和继承特性

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

function People(name, age) {
  this.name = name
  this.age = age
}
People.prototype.sayName = function () {
  console.log('my name is ' + this.name)
}

var p1 = new People(" 饥人谷 ");

p1.sayName()  //  my name is 饥人谷

问题3: prototype 是什么?有什么特性

prototype是指原型对象,JavaScript 的每个对象都继承另一个对象,后者称为“原型”(prototype)对象。只有null除外,它没有自己的原型对象。
通过构造函数生成实例对象时,会自动为实例对象分配原型对象。每一个构造函数都有一个prototype属性,这个属性就是实例对象的原型对象。
继承:原型对象上的所有属性和方法,都能被派生对象共享。这就是 JavaScript 继承机制的基本设计。

问题4:画出如下代码的原型图

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('前端');
1.PNG

问题5: 创建一个 Car 对象,拥有属性name、color、status;拥有方法run,stop,getStatus

function Car(name, color, status) {
  this.name = name
  this.color = color
  this.status = status
  this.run = function () {
     console.log('run')
  }
  this.stop = function () {
     console.log('run')
  }
  this.getState = function () {
     console.log(this.status)
  }
}
var car = new Car('F1', 'red', 'good')

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

  1. ct属性,GoTop 对应的 DOM 元素的容器
  2. target属性, GoTop 对应的 DOM 元素
  3. bindEvent 方法, 用于绑定事件
  4. createNode 方法, 用于在容器内创建节点
function GoTop(ct) {
    this.ct = ct || $('body')
    this.createNode = function () {
      var $button = $('<button>GoTop</button>')
      this.ct.append($button)
      return $button
    }
    this.target = this.createNode()
    this.bindEvent = function () {
      this.target.on('click',function () {
        $(window).scrollTop(0)
      })
    }

  }

  var b = new GoTop()
  b.bindEvent()

link

问题7: 使用木桶布局实现一个图片墙

link

上一篇 下一篇

猜你喜欢

热点阅读