javascript定义类的三种方法

原文地址:http://www.ruanyifeng.com/blog/2012/07/three_ways_to_define_a_javascript_class.html

一、构造函数法

这是经典方法,也是教科书必教的方法。它用构造函数模拟”类”,在其内部用this关键字指代实例对象。

function Cat() {
    this.name = "大毛";
  }

生成实例的时候,使用new关键字。

var cat1 = new Cat();
alert(cat1.name); // 大毛

类的属性和方法,还可以定义在构造函数的prototype对象之上。

Cat.prototype.makeSound = function(){
    alert("喵喵喵");
  }

二、Object.create()法

为了解决”构造函数法”的缺点,更方便地生成对象,Javascript的国际标准ECMAScript第五版(目前通行的是第三版),提出了一个新的方法Object.create()。

用这个方法,”类”就是一个对象,不是函数。

var Cat = {
    name: "大毛",
    makeSound: function(){ alert("喵喵喵"); }
 };

然后,直接用Object.create()生成实例,不需要用到new。

var cat1 = Object.create(Cat);
alert(cat1.name); // 大毛
cat1.makeSound(); // 喵喵喵

三、极简主义法

首先,它也是用一个对象模拟”类”。在这个类里面,定义一个构造函数createNew(),用来生成实例。

var Cat = {
    createNew: function(){
      // some code here
    }
};

然后,在createNew()里面,定义一个实例对象,把这个实例对象作为返回值。

var Cat = {
    createNew: function(){
      var cat = {};
      cat.name = "大毛";
      cat.makeSound = function(){ alert("喵喵喵"); };
      return cat;
    }
  };

使用的时候,调用createNew()方法,就可以得到实例对象。

var cat1 = Cat.createNew();
cat1.makeSound(); // 喵喵喵

可以实现继承,如下

var Animal = {
    createNew: function(){
      var animal = {};
      animal.sleep = function(){ alert("睡懒觉"); };
      return animal;
    }
  };
var Cat = {
    createNew: function(){
      var cat = Animal.createNew();
      cat.name = "大毛";
      cat.makeSound = function(){ alert("喵喵喵"); };
      return cat;
    }
  };
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
JavaScript中,我们可以使用三种不同的方法定义。 1. 构造函数方法:构造函数是一种特殊的函数,用于创建对象并初始化其属性。由于JavaScript中没有的概念,构造函数被广泛用于创建自定义对象。通过使用"new"关键字调用构造函数,可以创建一个新对象,并将构造函数中定义的属性和方法添加到该对象中。 示例: ``` function Person(name, age) { this.name = name; this.age = age; } var person1 = new Person("张三", 25); console.log(person1.name); // 输出:张三 console.log(person1.age); // 输出:25 ``` 2. 原型方法JavaScript中的每个对象都有一个原型(prototype),原型对象包含共享的属性和方法。我们可以使用原型对象来定义和共享的属性和方法。通过将属性和方法添加到的原型对象上,我们可以确保该的所有实例都可以访问和共享这些属性和方法。 示例: ``` function Person() {} Person.prototype.name = "张三"; Person.prototype.age = 25; var person1 = new Person(); console.log(person1.name); // 输出:张三 console.log(person1.age); // 输出:25 ``` 3. class关键字方法:在ECMAScript 2015(ES6)中,引入了class关键字,使我们能够更方便地定义和使用。使用class关键字定义具有构造函数和原型方法,它们与上述两种方法的实现方式非常相似。 示例: ``` class Person { constructor(name, age) { this.name = name; this.age = age; } } var person1 = new Person("张三", 25); console.log(person1.name); // 输出:张三 console.log(person1.age); // 输出:25 ``` 这些都是在JavaScript定义的常用方法,具体选择哪种方法,可以根据个人需求和代码风格来决定。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值