1.首先看一道题目

 function Cat(name,age){
this.name=name;
this.age=age;
}
console.log(new Cat('miaomiao',18));
//Cat {name: "miaomiao", age: 18}

2.那么这里面的this指的是什么呢

 function Cat(name,age){
console.log(this);//Cat {}
this.name=name;
this.age=age;
}
new Cat('miaomiao',18);

3.我们发现this是一个名为Cat的空对象,那么后两句(this.name=name;this.age=age)就相当于var Cat={};Cat.name=name;Cat.age=age;是这样的么我们来试一下

 function Cat(name,age){
var Cat = {};
Cat.name=name;
Cat.age=age;
}
console.log(new Cat('miaomiao',18));
//Cat {}

4.发现并不是那么回事,这是为什么,在javascript中如果没有return 那么函数就会默认return this为了验证我们在函数最后面return Cat即可

 function Cat(name,age){
var Cat = {};
Cat.name=name;
Cat.age=age;
return Cat;
}
console.log(new Cat('miaomiao',18));
//Object {name: "miaomiao", age: 18}

5.好像成功了,我们和之前对比一下

 function Cat(name,age){
this.name=name;
this.age=age;
}
console.log(new Cat('miaomiao',18));
//Cat {name: "miaomiao", age: 18}

6.函数的作用我们理解的差不多,下面开始探索NEW,试想如果我们不返回对象而是返回null或者其他类型的会是什么效果呢

 function Cat(name,age){
var Cat = {};
Cat.name=name;
Cat.age=age;
return undefined//或者null 123 '123'等非对象;
}
console.log(new Cat('miaomiao',18));//Cat{}

7.其他的一律输出空对象

那么我们试着写一个类似new的函数功能

 function Cat(name,age){
this.name=name;
this.age=age;
}
function New(){
var obj={};
var res=Cat.apply(obj,arguments);
return typeof res==='object'?res:obj
}
console.log(New('mimi',18))
//Object {name: "mimi", age: 18}

8.这样就大功告成了么  当然不是,我们接着往下看

  function Cat(name,age){
this.name=name;
this.age=age;
}
Cat.prototype.sayHi=function(){
console.log('hi')
}
function New(){
var obj={};
var res=Cat.apply(obj,arguments);
return typeof res==='object'?res:obj
} console.log(new Cat('mimi',18).sayHi())
console.log('-------------');
console.log(New('mimi',18).sayHi()); VM841:7 hi
VM841:15 undefined
VM841:16 -------------
VM841:17 Uncaught TypeError: New(...).sayHi is not a function(…)

9.红色的事报错,说明new操作不仅仅关注函数的本身 还关心他的原型 prototype

上面分析了那么多,现在进入正题。

  普通对象是没有prototype属性的,只有隐藏属性__proto__(IE上也有该隐藏属性,但是使用obj.__proto__不能输出东西,所以建议不要使用__proto__属性)。而函数对象则两者兼有。prototype属性指向的是函数对象的原型对象,对象的__proto__属性是创建实例对象的时候对应的函数对象的原型对象。

  function Cat(name,age){
this.name=name;
this.age=age;
}
Cat.prototype.sayHi=function(){
console.log('hi')
}
function New(){
var obj={};
obj.__proto__=Cat.prototype;
var res=Cat.apply(obj,arguments);
return typeof res==='object'?res:obj
} console.log(new Cat('mimi',18).sayHi())
console.log('-------------');console.log(New('mimi',18).sayHi()); VM844:7 hi
VM844:16 undefined
VM844:17 -------------
VM844:7 hi
VM844:17 undefined
undefined

10.ok大功告成

通过例子深入理解javascript中的new操作符的更多相关文章

  1. 深入理解JavaScript中创建对象模式的演变(原型)

    深入理解JavaScript中创建对象模式的演变(原型) 创建对象的模式多种多样,但是各种模式又有怎样的利弊呢?有没有一种最为完美的模式呢?下面我将就以下几个方面来分析创建对象的几种模式: Objec ...

  2. 深入理解JavaScript中的属性和特性

    深入理解JavaScript中的属性和特性 JavaScript中属性和特性是完全不同的两个概念,这里我将根据自己所学,来深入理解JavaScript中的属性和特性. 主要内容如下: 理解JavaSc ...

  3. 深入理解javascript中的立即执行函数(function(){…})()

    投稿:junjie 字体:[增加 减小] 类型:转载 时间:2014-06-12 我要评论 这篇文章主要介绍了深入理解javascript中的立即执行函数,立即执行函数也叫立即调用函数,通常它的写法是 ...

  4. 理解 JavaScript 中的 this

    前言 理解this是我们要深入理解 JavaScript 中必不可少的一个步骤,同时只有理解了 this,你才能更加清晰地写出与自己预期一致的 JavaScript 代码. 本文是这系列的第三篇,往期 ...

  5. 【拾遗】理解Javascript中的Arguments

    前言 最近在看JavaScript相关的知识点,看到了老外的一本Javascript For Web Developers,遇到了一个知识盲点,觉得老外写的很明白很透彻,记录下来加深印象,下面是我摘出 ...

  6. 理解javascript中的回调函数(callback)【转】

    在JavaScrip中,function是内置的类对象,也就是说它是一种类型的对象,可以和其它String.Array.Number.Object类的对象一样用于内置对象的管理.因为function实 ...

  7. 深入理解javascript中的立即执行函数

    这篇文章主要介绍了深入理解javascript中的立即执行函数,立即执行函数也叫立即调用函数,通常它的写法是用(function(){…})()包住业务代码,使用jquery时比较常见,需要的朋友可以 ...

  8. 深入理解JavaScript中的作用域和上下文

    介绍 JavaScript中有一个被称为作用域(Scope)的特性.虽然对于许多新手开发者来说,作用域的概念并不是很容易理解,我会尽我所能用最简单的方式来解释作用域.理解作用域将使你的代码脱颖而出,减 ...

  9. 理解JavaScript中的原型继承(2)

    两年前在我学习JavaScript的时候我就写过两篇关于原型继承的博客: 理解JavaScript中原型继承 JavaScript中的原型继承 这两篇博客讲的都是原型的使用,其中一篇还有我学习时的错误 ...

随机推荐

  1. 常用模块一(random模块、time模块、sys模块)

    一.random模块 import random # 1 取随机小数 应用:数学计算 ret = random.random() # 大于0且小于1之间的小数 print(ret) # 0.53559 ...

  2. 1、Python request(爬虫-百度翻译)

    #encoding=utf-8 import requests def fanyi(): while True: context = input("请输入翻译的内容(退出q):") ...

  3. SpringMVC 课纲

    SpringMVC 课纲 第一章 SpringMVC 架构 一个简单的 web 项目,校验器 SpringMVC 组件及相互关系 第二章 数据绑定 form标签库 第三章 Converter 和 Fo ...

  4. 打开一个vue项目

    1.cmd打开命令行工具 2.cd定位到目录 3.(sudo) cnpm install安装((sudo)npm install -g cnpm --registry=http://registry. ...

  5. 安装和使用jupyter

    安装 pip install jupyter 使用 jupyter notebook

  6. python常用模块——time模块

    参考博客:http://blog.csdn.net/SeeTheWorld518/article/details/48314501 http://www.jb51.net/article/49325. ...

  7. Linux下运行java项目

    最近初步接触了linux,感觉很有新鲜感.之前在windows下干过的事情也便想到在linux环境下实现一下.正好手头在编java,就想既然java可以在windows的DOS操作下运行,是不是也可以 ...

  8. Linux centos7 防火墙设置

    1.查看防火墙状态 systemctl list-unit-files|grep firewalld.service 或 systemctl status firewalld.service 2.开启 ...

  9. 灰色3D按钮组合

    在线演示 本地下载

  10. (十三)linux文件系统详解(基于ext2文件系统)【转】

    本文转载自:https://blog.csdn.net/FadeFarAway/article/details/53959639 我们知道,一个磁盘可以划分成多个分区,每个分区必须先用格式化工具(例如 ...