本文实例讲述了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测试上述代码运行效果。
js 定义类 ES5 ES6