下面是一篇关于在javascript中设置原型链的文章,主要介绍了什么是javascript的原型链、如何创建原型对象和如何创建实例对象。
一、javascript的原型链
javascript的原型链是指每个对象都有一个原型对象(prototype),原型对象中包含了属性和方法。当访问一个对象的属性和方法时,javascript会先查找该对象本身是否存在该属性和方法,如果不存在,则会沿着该对象的原型链向上查找,直到找到该属性或方法为止。如果整个原型链中都找不到该属性或方法,则返回undefined。
我们可以通过javascript的原型链机制来实现对象属性和方法的共享,从而达到代码复用和优化的效果。通常,在实现继承功能时,我们会使用原型链机制来继承父对象上的属性和方法,从而达到代码复用的效果。
二、创建原型对象
在javascript中,我们可以通过构造函数或对象字面量来创建原型对象。构造函数的原型对象可以通过prototype属性来访问和设置。对象字面量的原型对象可以通过__proto__属性来访问和设置。
1、使用构造函数创建原型对象
示例代码如下:
function person(name, age) { this.name = name; this.age = age;}person.prototype.sayhello = function() { console.log('hello, ' + this.name);};
在上面的示例中,我们定义了一个person构造函数,使用prototype属性向其原型对象中添加了一个sayhello方法。
使用构造函数创建的原型对象会被实例对象所共享,因此,我们可以通过创建实例对象来访问和调用原型对象上的属性和方法。
示例代码如下:
var person = new person('jack', 20);person.sayhello(); // 输出:hello, jack
在上面的示例代码中,我们首先通过person构造函数创建了一个person对象实例,然后通过调用sayhello方法输出了一条问候语。
2、使用对象字面量创建原型对象
示例代码如下:
var person = { name: '', age: '', sayhello: function() { console.log('hello, ' + this.name); }};
在上面的示例代码中,我们使用了对象字面量来创建了一个person对象,对象中包含了name、age和sayhello属性和方法。另外,在对象字面量中,我们可以使用__proto__属性来访问和设置其原型对象。
示例代码如下:
var person1 = { name: 'jack', age: 20,};var person2 = { name: 'lucy', age: 18,};person1.__proto__ = person;person2.__proto__ = person;person1.sayhello(); // 输出:hello, jackperson2.sayhello(); // 输出:hello, lucy
在上面的示例代码中,我们首先创建了person1和person2两个实例对象,然后通过__proto__属性将它们的原型对象指向了上面定义的person对象,从而实现了对sayhello方法的共享,并且可以在实例对象中直接访问和调用该方法。
三、创建实例对象
在javascript中,我们可以通过构造函数或对象字面量来创建实例对象。构造函数创建实例对象时,使用new关键字,可以自动调用构造函数,返回新的实例对象。对象字面量直接创建实例对象。
1、使用构造函数创建实例对象
示例代码如下:
function person(name, age) { this.name = name; this.age = age;}person.prototype.sayhello = function() { console.log('hello, ' + this.name);};var person = new person('jack', 20);person.sayhello(); // 输出:hello, jack
在上面的示例代码中,我们首先定义了一个person构造函数,并为其原型对象添加了一个sayhello方法。然后,我们使用new关键字调用person构造函数,创建了一个person对象实例,并通过调用sayhello方法输出了一条问候语。
2、使用对象字面量创建实例对象
示例代码如下:
var person = { name: '', age: '', sayhello: function() { console.log('hello, ' + this.name); }};var person1 = object.create(person);person1.name = 'jack';person1.age = 20;person1.sayhello(); // 输出:hello, jackvar person2 = object.create(person);person2.name = 'lucy';person2.age = 18;person2.sayhello(); // 输出:hello, lucy
在上面的示例代码中,我们首先使用对象字面量创建了一个person对象,然后使用object.create方法创建了两个实例对象person1和person2,并将它们的原型对象指定为person对象。最后,我们为person1和person2对象分别设置了name和age属性,通过调用sayhello方法输出了问候语。
以上就是javascript怎么设置原型链的详细内容。
