每一个JavaScript对象有一个原型,prototype也是一个对象。所有的JavaScript对象继承的属性和方法从它们的prototype。
使用对象字面量创建对象,或者使用new Object(),从一个称作Object.prototype的原型(prototype)继承。使用 new Date()创建对象,继承Date.prototype。
Object.prototype 是原型链的顶级原型。所有的JavaScript对象(Date, Array, RegExp, Function, ....) 都继承Object.prototype。
创建对象原型的标准方法是使用对象构造函数:
function Person(first, last, age, eyecolor) {
this.firstName = first;
this.lastName = last;
this.age = age;
this.eyeColor = eyecolor;
}
使用构造函数,可以使用new关键字从同一原型创建新对象。
var myFather = new Person("John", "Doe", 50, "blue");
var myMother = new Person("Sall", "Rally", 60, "green");
构造函数是Person对象的原型,用大写字母命名构造函数是很好的做法。
项目
不能将新属性添加到原型中,就像将新属性添加到现有对象一样,因为该原型不是现有对象。
Person.nationality = "Chinese";
若要向原型添加新属性,必须将其添加到构造函数:
function Person(first, last, age, eyecolor) {
this.firstName = first;
this.lastName = last;
this.age = age;
this.eyeColor = eyecolor;
this.nationality = "Chinese";
}
原型属性可以有原型值(默认值)。
构造函数也可以定义方法:
有时,希望向现有对象添加新属性,(或方法),希望将新属性(或方法)添加到给定类型的所有现有对象中,您向对象原型添加新属性(或方法)。
向现有对象添加新属性很容易。
myFather.nationality = "English";
属性将被添加到myFather,不是myMother,也不是任何其他person对象。
向现有对象添加新方法也很容易:
myFather.name = function () {
return this.firstName + " " + this.lastName;
};
方法将被添加到myFather。不是myMother。
JavaScript prototype属性允许你为一个已经存在的原型添加新的属性:
JavaScript原型属性还允许您添加新的方法对现有的原型:
只修改你设定的自己原型。不修改标准的JavaScript对象的原型。
本文基于JavaScript基础。介绍了JavaScript对象原型的基础知识点。如何在原型的基础上添加属性和方法。如何在对象在添加属性和方法。以及使用prototype属性允许你为一个已经存在的原型添加新的属性。每个模块都做了详细讲解,代码的展示。
使用编程语言,希望能够帮助你学习。
新闻名称:一篇文章带你了解JavaScript对象原型
网站地址:http://www.csdahua.cn/qtweb/news10/433310.html
网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网