成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

一篇文章帶你了解JavaScript對象原型

開發(fā) 前端
每一個JavaScript對象有一個原型,prototype也是一個對象。所有的JavaScript對象繼承的屬性和方法從它們的prototype。

每一個JavaScript對象有一個原型,prototype也是一個對象。所有的JavaScript對象繼承的屬性和方法從它們的prototype。

一、JavaScript 原型

使用對象字面量創(chuàng)建對象,或者使用new Object(),從一個稱作Object.prototype的原型(prototype)繼承。使用 new Date()創(chuàng)建對象,繼承Date.prototype。

Object.prototype 是原型鏈的頂級原型。所有的JavaScript對象(Date, Array, RegExp, Function, ....) 都繼承Object.prototype。

1. 創(chuàng)建一個原型

創(chuàng)建對象原型的標(biāo)準(zhǔn)方法是使用對象構(gòu)造函數(shù):

function Person(first, last, age, eyecolor) {
    this.firstName = first;
    this.lastName = last;
    this.age = age;
    this.eyeColor = eyecolor;
}

使用構(gòu)造函數(shù),可以使用new關(guān)鍵字從同一原型創(chuàng)建新對象。

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

構(gòu)造函數(shù)是Person對象的原型,用大寫字母命名構(gòu)造函數(shù)是很好的做法。

完整代碼:

<!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. 原型添加屬性

不能將新屬性添加到原型中,就像將新屬性添加到現(xiàn)有對象一樣,因為該原型不是現(xiàn)有對象。

Person.nationality = "Chinese";

若要向原型添加新屬性,必須將其添加到構(gòu)造函數(shù):

function Person(first, last, age, eyecolor) {
    this.firstName = first;
    this.lastName = last;
    this.age = age;
    this.eyeColor = eyecolor;
    this.nationality = "Chinese";
}

原型屬性可以有原型值(默認(rèn)值)。

3. 為原型添加方法

構(gòu)造函數(shù)也可以定義方法:

<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>

二、向?qū)ο筇砑訉傩院头椒?/h3>

有時,希望向現(xiàn)有對象添加新屬性,(或方法),希望將新屬性(或方法)添加到給定類型的所有現(xiàn)有對象中,您向?qū)ο笤吞砑有聦傩裕ɑ蚍椒ǎ?/p>

1. 向?qū)ο筇砑訉傩?/h4>

向現(xiàn)有對象添加新屬性很容易。

myFather.nationality = "English";

屬性將被添加到myFather,不是myMother,也不是任何其他person對象。

2. 向?qū)ο筇砑臃椒?/h4>

向現(xiàn)有對象添加新方法也很容易:

myFather.name = function () {
    return this.firstName + " " + this.lastName;
};

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

三、使用 prototype 屬性

JavaScript prototype屬性允許你為一個已經(jīng)存在的原型添加新的屬性:

<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原型屬性還允許您添加新的方法對現(xiàn)有的原型:

<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>

圖片

只修改你設(shè)定的自己原型。不修改標(biāo)準(zhǔn)的JavaScript對象的原型。

四、總結(jié)

本文基于JavaScript基礎(chǔ)。介紹了JavaScript對象原型的基礎(chǔ)知識點。如何在原型的基礎(chǔ)上添加屬性和方法。如何在對象在添加屬性和方法。以及使用prototype屬性允許你為一個已經(jīng)存在的原型添加新的屬性。每個模塊都做了詳細(xì)講解,代碼的展示。

使用編程語言,希望能夠幫助你學(xué)習(xí)。

責(zé)任編輯:華軒 來源: 前端進階學(xué)習(xí)交流
相關(guān)推薦

2020-10-22 09:08:34

JavaScript

2021-07-02 10:00:50

JavaScriptObject 函數(shù)

2024-09-02 14:07:05

2023-07-06 14:40:38

2023-07-25 16:06:57

JavaScript對象

2023-08-27 15:18:17

JavaScriptRegExp

2024-07-02 14:14:18

2023-09-06 14:57:46

JavaScript編程語言

2021-05-18 08:30:42

JavaScript 前端JavaScript時

2021-06-24 09:05:08

JavaScript日期前端

2021-01-26 23:46:32

JavaScript數(shù)據(jù)結(jié)構(gòu)前端

2021-03-05 18:04:15

JavaScript循環(huán)代碼

2021-03-09 14:04:01

JavaScriptCookie數(shù)據(jù)

2024-04-19 14:23:52

SwitchJavaScript開發(fā)

2023-07-30 15:18:54

JavaScript屬性

2024-01-30 13:47:45

2020-11-10 10:48:10

JavaScript屬性對象

2021-06-04 09:56:01

JavaScript 前端switch

2021-01-29 18:41:16

JavaScript函數(shù)語法

2021-02-02 18:39:05

JavaScript
點贊
收藏

51CTO技術(shù)棧公眾號

主站蜘蛛池模板: 福利网站在线观看 | 超碰在线亚洲 | 国产一级免费视频 | 国精产品一品二品国精在线观看 | 国产精品成av人在线视午夜片 | 亚洲一区二区精品视频在线观看 | 久久久久国产 | 黄色大片免费观看 | 国产精品国产三级国产aⅴ无密码 | 精品欧美一区二区在线观看视频 | 精品久久久久久 | 一区二区三区精品在线 | 五月婷婷激情 | 精品永久| 一区二区三区电影在线观看 | 久久黄视频 | 国产精品一区视频 | 国产91丝袜在线播放 | 91国产精品在线 | 国产一区二区三区在线看 | 日韩在线视频一区 | 国产免费一区二区 | 在线观看av不卡 | 日韩国产欧美一区 | 国内精品久久久久久久 | 日本中文字幕一区 | 亚洲高清视频在线观看 | 亚洲精品区 | 国产精品毛片久久久久久久 | 精品亚洲一区二区三区 | 国产一区不卡 | 国产精品久久亚洲7777 | 久久亚洲国产精品日日av夜夜 | 久久久久久亚洲 | 狠狠干美女 | 成人在线视频免费观看 | 国产大片一区 | 国产在线精品一区二区三区 | 国产精品亚洲成在人线 | 日本天天操 | 午夜精品一区二区三区免费视频 |