JavaScript

超轻量级php框架startmvc

js定义类的方法示例【ES5与ES6】

更新时间:2020-09-06 05:54:01 作者:startmvc
本文实例讲述了js定义类的方法。分享给大家供大家参考,具体如下:以下是es5标准里定义

本文实例讲述了js定义类的方法。分享给大家供大家参考,具体如下:

以下是es5标准里定义类的方法:


<script>
function Point(x,y){
 this.x=x;
 this.y=y;
}
Point.prototype.toString=function(){
 return '('+this.x+', '+this.y+')';
}
var point=new Point(1,2);
console.log(point);
</script>

运行结果:

上面这样用构造函数和原型混合的方法定义类,是为了每次new新实例时可以共享方法,不用创建function新实例。所以只有函数属性放在原型对象里定义,其他属性都在构造函数里定义。

es6里简化了类的定义方法:


<script>
class Point{
 constructor(x,y){
 this.x=x;
 this.y=y;
 }
 toString(){
 return '('+this.x+', '+this.y+')';
 }
}
let point=new Point(3,4);
console.log(point);
</script>

运行结果:

注意:类名首字母要大写

另:原文代码中class Point(x,y)定义会导致运行错误,本文予以修正。)

感兴趣的朋友可以使用在线HTML/CSS/JavaScript代码运行工具:http://tools.jb51.net/code/HtmlJsRun测试上述代码运行效果。