javascript对象声明方式不同,打印结果也不一样
伊谢尔伦
伊谢尔伦 2017-04-11 12:39:09
[JavaScript讨论组]

第一种写法

var stone={
    weight:100
}
// function stone() {
//     this.weight=100;
// }
function Bench() {
    this.legth=100;
    this.width=50;
    this.weight=60;
}
Bench.prototype=stone;

var b=new Bench();

console.log(b);
console.log(Object.getPrototypeOf(b));


结果:



第二种写法:

function stone() {
    this.weight=100;
}
function Bench() {
    this.legth=100;
    this.width=50;
    this.weight=60;
}
Bench.prototype=new stone;

var b=new Bench();

console.log(b);
console.log(Object.getPrototypeOf(b));

为什么会这样,第二种前面会带stone??

伊谢尔伦
伊谢尔伦

小伙看你根骨奇佳,潜力无限,来学PHP伐。

全部回复(3)
PHP中文网

我在chrome运行的结果和你的不一样……

  1. 第一种的运行结果

    Bench {legth: 100, width: 50, weight: 60}
    Object {weight: 100}
  2. 第二种运行结果

    Bench {legth: 100, width: 50, weight: 60}
    stone {weight: 100}

这之中的区别很简单啊,console.log对象的时候,前面那串就是它构造函数的名字,第一种代码里面,stone对象使用对象直接量创建的,构造函数当然是Object;然而在第二种代码里面,stone成了个构造函数,打印它的实例,前面显示的当然是它这个构造函数的名字。

PHPz

这个涉及到创建对象的两种方式:构造函数模式和原型模式
一个是实例一个是原型,水平有限,我一两句说不清楚,还是你自己找找看看,可能理解的快一点

天蓬老师

我认为你可能对对象的原型和构造函数不是很理解

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

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