javascript对象声明方式不同,打印结果也不一样

查看:154
本文介绍了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??

解决方案

我在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成了个构造函数,打印它的实例,前面显示的当然是它这个构造函数的名字。

这篇关于javascript对象声明方式不同,打印结果也不一样的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆