`

javascript继承--prototype简单解释

阅读更多

javascript继承==>prototype简单使用

1,原型链实例

2,将公共属性迁移到原型中

3,只继承原型

4,临时构造器--new F()使用

下面写的简单实例:

 

function shape(){}

shape.prototype.name = 'name';

shape.prototype.toString = function(){

return this.name

}

 

function tweShape(){}

var F = function(){}

F.prototype = shape.prototype;

tweShape.prototype = new F();

tweShape.prototype.constructor = tweShape;

tweShape.prototype.name= '2d Shape';

 

function triangle(side,height){

    this.side = side;

    this.height = height;

}

var F = function(){}

F.prototype = tweShape.prototype

triangle.prototype = new F();

triangle.prototype.constructor = triangle;

triangle.prototype.name = 'Triangle';

triangle.prototype.getArea = function(){

    return this.side * this.height / 2;

}

 

chrom浏览器console控制台进行调试如下:

var tri = new triangle(10,15);

tri.getArea();

==>75

 

tri.constructor

==>function triangle(side,height){

            this.side = side;

            this.height = height;

      }

 

var twe = new tweShape();

twe.constructor;

=>function tweShape(){}

twe.name;

=>2d Shape

 

var shp = new shape();

shp.construtor;

=>function shape(){}

shp.name

=>name

 

如果我们不使用临时构造器,在实例化shape和tweShape执行的原型都是triange,输入对应的实例化对象

twe.name 或者 shp.name结果都是

==>Triangle

分享到:
评论

相关推荐

    getter-in-value-prototype.rar_prototype

    在JavaScript中,`prototype`是一个核心概念,它与对象的继承和方法共享密切相关。当我们谈论“getter in value prototype”时,我们关注的是如何在对象的原型链上定义和调用getter函数,这是一个用于获取对象属性值...

    ember-disable-prototype-extensions-源码.rar

    在JavaScript中,对象可以通过原型链实现继承。通过`Object.prototype`,我们可以为所有对象添加方法。然而,一些库或框架,包括Ember,有时会直接扩展JavaScript的基本类型(如Array、String、Number等)的原型,以...

    extends-js:JavaScript继承-正确的方法

    扩展js Javascript继承-正确的方法。 比您在其他地方看到的要好。 要在浏览器中使用,只需将extends.js添加到您的项目中: [removed][removed]要在您的节点项目中使用,请通过npm安装: npm install extends-js只需...

    JavaScript 继承详解(六)

    在本章中,我们将分析Prototypejs中关于JavaScript继承的实现。 Prototypejs是最早的JavaScript类库,可以说是JavaScript类库的鼻祖。 我在几年前接触的第一个JavaScript类库就是这位,因此Prototypejs有着广泛的...

    javascript的prototype继承

    JavaScript的原型继承是其面向对象编程的一大特性,它基于原型链机制实现,允许一个对象可以从另一个对象继承属性和方法。这种继承方式不同于类继承,而是通过将子类的原型对象设置为父类的一个实例来实现。 在...

    javascript中类和继承(代码示例+prototype.js)

    本文将深入探讨JavaScript中的类和继承,并结合`prototype.js`文件中的示例进行解析。 ### 类的概念与模拟 在JavaScript中,我们通常使用函数来模拟类的行为。一个函数可以看作是一个类的定义,通过`new`关键字来...

    JavaScript教程--从入门到精通

    理解原型和原型链是掌握JavaScript面向对象编程的关键,这涉及到对象的继承、方法的调用以及如何使用Object.create()、__proto__和prototype属性。 事件处理是JavaScript在网页交互中不可或缺的部分。你将学习如何...

    javascript基础-->中级-->高级-->面向对象

    2. prototype与__proto__:两者都与原型链有关,prototype是构造函数的属性,__proto__是实例对象的属性,它们连接了对象间的继承关系。 3. 类与继承:ES6引入了class关键字,虽然在语法上更像传统的面向对象语言,...

    JavaScript继承

    原型(Prototype)是JavaScript实现继承的基础,每个对象都有一个`__proto__`属性,指向创建它的构造函数的原型对象。通过原型,子类可以共享父类的属性和方法,减少了代码的重复。此外,JavaScript的灵活性允许...

    JavaScript的prototype

    JavaScript中的`prototype`是一个核心概念,它涉及到对象继承和函数原型。在JavaScript中,每创建一个函数,该函数就会自动获得一个名为`prototype`的属性,这个属性是一个对象,用于实现对象间的继承。同时,每个...

    JS封装和继承-入门级

    5. **寄生组合式继承**:结合了寄生式继承和组合继承的优点,是JavaScript中推荐的继承方式,可以在`Javascript面向对象编程(三):非构造函数的继承.docx`中找到更详细的解释。 例如,使用寄生组合式继承: ```...

    第十二课 继承-011

    在前端开发中,JavaScript 是一种常用的面向对象编程语言,它提供了继承这一机制,使得我们可以创建新的对象类,这些新类可以扩展已有的类的功能。在本节课程“第十二课 继承-011”中,我们将深入探讨 JavaScript 中...

    JavaScript 学习 - 提高篇

    ### JavaScript 学习 - 提高篇 ...总之,在 JavaScript 中,对象是非常强大的概念,它不仅支持简单的键值对存储,还能够通过函数和原型链来实现复杂的逻辑和行为。掌握对象的概念对于深入理解 JavaScript 至关重要。

    JavaScript项目-门户网站

    8. **面向对象编程**:可能涉及到JavaScript的类(class)和原型(prototype)机制,学习如何创建和使用对象,以及继承和多态的概念。 9. **错误处理**:理解如何使用`try...catch`语句来捕获和处理运行时错误,...

    tooltip-js-with-inheritance-prototype:使用原型继承设计模式的css,html,js的简单工具提示

    此项目“tooltip-js-with-inheritance-prototype”旨在展示如何利用原型继承设计模式创建一个简单的工具提示功能,涉及到CSS、HTML和JavaScript的结合应用。 首先,让我们深入了解JavaScript中的原型继承。在...

    Advanced JavaScript (closures,prototype,inheritance)

    JavaScript,作为一种广泛应用于Web开发的脚本语言,其高级特性如闭包(closures)、原型(prototype)和继承(inheritance)是理解其精髓的关键。本文将深入探讨这些概念,帮助开发者更好地掌握JavaScript的核心。 ...

    【技术分享】从浅入深 Javascript 原型链与原型链污染 .pdf

    JavaScript 原型链是语言的核心特性之一,它在实现对象的继承和共享属性时起着关键作用。本文将深入探讨JavaScript原型链的工作原理及其可能导致的安全问题——原型链污染。 首先,JavaScript 中的对象继承并不像...

    prototype(JS类库).rar

    Prototype的核心理念是通过模拟传统面向对象编程语言的特性,如类、继承和封装,来提升JavaScript的开发体验。 **Prototype的主要版本** 1. **Prototype 1.4**:这个版本为开发者引入了基础的类和对象的概念,使得...

    JavaScript类和继承 prototype属性

    我们已经在第一章中使用prototype属性模拟类和继承的实现。 prototype属性本质上还是一个JavaScript对象。 并且每个函数都有一个默认的prototype属性。 如果这个函数被用在创建自定义对象的场景中,我们称这个函数为...

    理解Javascript原型继承原理

    通过以上分析,我们可以看到,在JavaScript中,通过`prototype`和`[[Prototype]]`实现了非常灵活的继承机制。这种机制允许我们轻松地扩展和重用现有对象的功能,同时也使得JavaScript成为一种非常适合面向对象编程的...

Global site tag (gtag.js) - Google Analytics