javascript - 为什么实例对象调用方法的值不会随原型的改变而改变
PHP中文网
PHP中文网 2017-04-10 18:05:06
[JavaScript讨论组]

看书看到的例子:

var Car = function (wheelCount) {
    this.wheels = wheelCount || 4;
}

Car.prototype.odometer = 0;

Car.prototype.drive = function (miles) {
    this.odometer += miles;
    return this.odometer;
}

var tesla = new Car();

Car.prototype.odometer = 200;

tesla.drive(10) //210

Car.prototype.odometer = 2000;

tesla.drive(10) //220

第二次调用tesla.drive(10)时是220而不是2010,我的理解是因为实例化对象在调用函数以后其内部创建了自己的odometer变量环境就与原型无关了,书上没有说明原因不知道我理解的对不对,还望指教。谢谢。

PHP中文网
PHP中文网

认证高级PHP讲师

全部回复(5)
PHPz

你的代码

var tesla = new Car();

Car.prototype.odometer = 200;

tesla.drive(10) //210 (经过这次drive,在tesla上创建了odometer属性)

Car.prototype.odometer = 2000;(这个只改了原型)

tesla.drive(10) //220(这个操作的是属性)

这样改一下,因为在原型里面用this.xxx =yyy 赋值,如果不存在会创建对象的属性,下一次再操作原型,显示的就是属性的值,而不是原型上的值。

这是你要的效果

var Car = function (wheelCount) {
  this.wheels = wheelCount || 4;
}

Car.prototype.odometer = 0;

Car.prototype.drive = function (miles) {
  **this.__proto__.odometer** += miles;
  console.log(this.odometer);
};

var tesla = new Car();

Car.prototype.odometer = 200;

tesla.drive(10) //210   

Car.prototype.odometer = 2000;

tesla.drive(10) //2010
ringa_lee

你这里的this.odometer是+=,分解之后其实是this.odometer=this.odometer+xx。
也就是this.odometer=this.__proto__.odometer+xx。
所以是取原型的值来设置对象的属性值。

黄舟

操作的是对象的odometer属性不是原型上的odometer吧

PHP中文网

this.odometer += miles;赋值的时候由于本身没有odometer会自身创建一个属性,所以下一次调用的时候就调用自身的odometer是210

伊谢尔伦

drive方法中,this.odometer += miles;语句中的this是实例化对象,即tesla。
你return的也是tesla的odometer属性。

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号