前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >一篇文章带你了解JavaScript对象原型

一篇文章带你了解JavaScript对象原型

作者头像
前端进阶者
发布2021-01-22 10:08:14
5670
发布2021-01-22 10:08:14
举报
文章被收录于专栏:前端进阶交流

每一个JavaScript对象有一个原型,prototype也是一个对象。所有的JavaScript对象继承的属性和方法从它们的prototype。

一、JavaScript 原型

使用对象字面量创建对象,或者使用new Object(),从一个称作Object.prototype的原型(prototype)继承。使用 new Date()创建对象,继承Date.prototype。

Object.prototype 是原型链的顶级原型。所有的JavaScript对象(Date, Array, RegExp, Function, ....) 都继承Object.prototype。

1. 创建一个原型

创建对象原型的标准方法是使用对象构造函数:

代码语言:javascript
复制
function Person(first, last, age, eyecolor) {
    this.firstName = first;
    this.lastName = last;
    this.age = age;
    this.eyeColor = eyecolor;
}

使用构造函数,可以使用new关键字从同一原型创建新对象。

代码语言:javascript
复制
var myFather = new Person("John", "Doe", 50, "blue");
var myMother = new Person("Sall", "Rally", 60, "green");

构造函数是Person对象的原型,用大写字母命名构造函数是很好的做法。

完整代码:

代码语言:javascript
复制
<!DOCTYPE html>
<html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>项目</title>
    </head>
    <body style="background-color: aqua;">
        <p id="demo"></p>

        <script>
            function Person(first, last, age, eye) {
                this.firstName = first;
                this.lastName = last;
                this.age = age;
                this.eyeColor = eye;
            }

            var myFather = new Person("John", "Doe", 50, "blue");
            var myMother = new Person("Sall", "Rally", 60, "green");

            document.getElementById("demo").innerHTML =
                "My father is " + myFather.age + ". My mother is " + myMother.age;
</script>
    </body>
</html>
2. 原型添加属性

不能将新属性添加到原型中,就像将新属性添加到现有对象一样,因为该原型不是现有对象。

代码语言:javascript
复制
Person.nationality = "Chinese";

若要向原型添加新属性,必须将其添加到构造函数:

代码语言:javascript
复制
function Person(first, last, age, eyecolor) {
    this.firstName = first;
    this.lastName = last;
    this.age = age;
    this.eyeColor = eyecolor;
    this.nationality = "Chinese";
}

原型属性可以有原型值(默认值)。

3. 为原型添加方法

构造函数也可以定义方法:

代码语言:javascript
复制
 <script>
    function Person(first, last, age, eye) {
        this.firstName = first;
        this.lastName = last;
        this.age = age;
        this.eyeColor = eye;
        this.name = function() {
            return this.firstName + " " + this.lastName
        };
    }

    var myFather = new Person("John", "ele", 50, "blue");
    document.getElementById("demo").innerHTML =
    "My father is " + myFather.name();
</script>

二、向对象添加属性和方法

有时,希望向现有对象添加新属性,(或方法),希望将新属性(或方法)添加到给定类型的所有现有对象中,您向对象原型添加新属性(或方法)。

1. 向对象添加属性

向现有对象添加新属性很容易。

代码语言:javascript
复制
myFather.nationality = "English";

属性将被添加到myFather,不是myMother,也不是任何其他person对象。

2. 向对象添加方法

向现有对象添加新方法也很容易:

代码语言:javascript
复制
myFather.name = function () {
    return this.firstName + " " + this.lastName;
};

方法将被添加到myFather。不是myMother。

三、使用 prototype 属性

JavaScript prototype属性允许你为一个已经存在的原型添加新的属性:

代码语言:javascript
复制
<script>
  function Person(first, last, age, eye) {
      this.firstName = first;
      this.lastName = last;
      this.age = age;
      this.eyeColor = eye;
  }
  Person.prototype.nationality = "Math";

  var myFather = new Person("John", "Doe", 50, "blue");
  document.getElementById("demo").innerHTML =
  "My father is " + myFather.nationality;
</script>

JavaScript原型属性还允许您添加新的方法对现有的原型:

代码语言:javascript
复制
 <script>
    function Person(first, last, age, eye) {
        this.firstName = first;
        this.lastName = last;
        this.age = age;
        this.eyeColor = eye;
    }
    Person.prototype.name = function() {
        return this.firstName + " " + this.lastName
    };

    var myFather = new Person("name", "oe", 50, "blue");
    document.getElementById("demo").innerHTML =
    "My father is " + myFather.name();
</script>

只修改你设定的自己原型。不修改标准的JavaScript对象的原型。

四、总结

本文基于JavaScript基础。介绍了JavaScript对象原型的基础知识点。如何在原型的基础上添加属性和方法。如何在对象在添加属性和方法。以及使用prototype属性允许你为一个已经存在的原型添加新的属性。每个模块都做了详细讲解,代码的展示。

使用编程语言,希望能够帮助你学习。

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2020-09-08,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 前端进阶学习交流 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 一、JavaScript 原型
    • 1. 创建一个原型
      • 2. 原型添加属性
        • 3. 为原型添加方法
        • 二、向对象添加属性和方法
          • 1. 向对象添加属性
            • 2. 向对象添加方法
            • 三、使用 prototype 属性
            • 四、总结
            领券
            问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档