对JavaScript中原型的理解

本文深入探讨了如何将面向对象编程思想从Java移植到JavaScript,特别关注JavaScript中对象和类的概念,以及原型对象的特性与应用。文章解释了JavaScript中通过原型对象实现类的扩展,以及如何灵活地添加方法和属性,同时强调了这一特性对封装性的挑战。通过具体示例,展示了如何在自定义类中利用原型对象来添加功能,以及与Java类定义的区别。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

从纯粹的面向对象思想(Java思想)向Javascript语言面向对象思想的转化,经历沉痛而惨烈。Javascript中对象和类的概念转化悄然不动声色,让人迷糊。有时候,对Java理解得越清楚,对Javascript理解起来就越费劲。尤其对Javascript的原型对象的理解颇费功夫。

按照定义,每个javascript对象都有一个原型对象(简称原型),这个原型是由该对象的构造函数所定义(javascript自动创建的),并且对象继承原型的所有属性和方法(函数),比如 一个String对象 的原型为 String.prototype ,如果我们想要给String类添加方法,可以这样做(比如添加常用的trim()方法):

js 代码

String.prototype.trim = function (){ return this.replace(/(^\s*)|(\s*$)/g, ""); }

这个特性是相当令人惊讶的,因为这破坏了封装性,就好像在Java中你可以对String类直接进行修改一样。function() 可以当作数据来给左操作数赋值(而不仅仅是当作动作),也跟Java非常地不同。

对于Javascript内部类都可以这么改,对于自定义类当然可以这么改,如:

function Circle(x,y,r){ this.x = x; this.y = y; this.r = r; //this.prototype = null ; /*这句代码可以看作是隐含存在的,因为javascript 中“类”的定义和函数的定义结构上没有差异,所以可以说,所有函数都隐藏有这样一个属性。*/ }

然后,我们给原型加一个得到面积的方法:

Circle.prototype.area = function(){ return this.r * this.r * 3.14159 ; }

可以这样使用:


var circ = new Circle(0,0,2) ; alert(circ.area()) ;

当然,我们也可以在类中很轻松的定义我们想要实现的方法,如,还是上面那个求圆面积:

function Circle(x,y,r){ this.x = x; this.y = y; this.r = r ; this.area = function (){ return this.r * this.r * 3.14159 ; } } //调用: var circ = new Circle(0,0,2) ; alert(circ.area()) ;

两者的调用代码完全一样,那为什么要使用原型呢?我感觉主要是为了解决对内部类型的继承问题,也就是说当你无法修改String的构造函数而想要让所有String实例都具有某一方法的时候,你可以用这个prototype;或者说,你用这个prototype来模拟实现String类的子类,达到对父类进行扩展的目的。

参考:

JavaScript权威指南(第四版)





评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值