通过例子深入理解javascript中的new操作符
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操作符的更多相关文章
- 深入理解JavaScript中创建对象模式的演变(原型)
深入理解JavaScript中创建对象模式的演变(原型) 创建对象的模式多种多样,但是各种模式又有怎样的利弊呢?有没有一种最为完美的模式呢?下面我将就以下几个方面来分析创建对象的几种模式: Objec ...
- 深入理解JavaScript中的属性和特性
深入理解JavaScript中的属性和特性 JavaScript中属性和特性是完全不同的两个概念,这里我将根据自己所学,来深入理解JavaScript中的属性和特性. 主要内容如下: 理解JavaSc ...
- 深入理解javascript中的立即执行函数(function(){…})()
投稿:junjie 字体:[增加 减小] 类型:转载 时间:2014-06-12 我要评论 这篇文章主要介绍了深入理解javascript中的立即执行函数,立即执行函数也叫立即调用函数,通常它的写法是 ...
- 理解 JavaScript 中的 this
前言 理解this是我们要深入理解 JavaScript 中必不可少的一个步骤,同时只有理解了 this,你才能更加清晰地写出与自己预期一致的 JavaScript 代码. 本文是这系列的第三篇,往期 ...
- 【拾遗】理解Javascript中的Arguments
前言 最近在看JavaScript相关的知识点,看到了老外的一本Javascript For Web Developers,遇到了一个知识盲点,觉得老外写的很明白很透彻,记录下来加深印象,下面是我摘出 ...
- 理解javascript中的回调函数(callback)【转】
在JavaScrip中,function是内置的类对象,也就是说它是一种类型的对象,可以和其它String.Array.Number.Object类的对象一样用于内置对象的管理.因为function实 ...
- 深入理解javascript中的立即执行函数
这篇文章主要介绍了深入理解javascript中的立即执行函数,立即执行函数也叫立即调用函数,通常它的写法是用(function(){…})()包住业务代码,使用jquery时比较常见,需要的朋友可以 ...
- 深入理解JavaScript中的作用域和上下文
介绍 JavaScript中有一个被称为作用域(Scope)的特性.虽然对于许多新手开发者来说,作用域的概念并不是很容易理解,我会尽我所能用最简单的方式来解释作用域.理解作用域将使你的代码脱颖而出,减 ...
- 理解JavaScript中的原型继承(2)
两年前在我学习JavaScript的时候我就写过两篇关于原型继承的博客: 理解JavaScript中原型继承 JavaScript中的原型继承 这两篇博客讲的都是原型的使用,其中一篇还有我学习时的错误 ...
随机推荐
- Springboot 错误信息:Required String parameter 'loginname' is not present 引发的研究
@PostMapping("/reg/change")public CommonSdo change( @RequestParam(value = "oldPasswor ...
- 小程序发送 request请求失败 提示不在合法域名列表中的解决方法
可以在小程序开发工具中设置不校验域名.
- python常用模块——random模块
参考博客:http://www.360doc.com/content/14/0430/11/16044571_373443266.shtml 今天突然想起python该怎么生成随机数?查了一下,贴出实 ...
- Spring:笔记整理(2)——IOC容器
IOC容器 什么是IOC 说明 IOC ,全称Inversion of control,即,控制反转,是一种设计思想. 控制: 在Java中,IOC意味着:你将设计好的对象交给容器控制,而不是传统的在 ...
- Oracle索引(1)概述与创建索引
索引是为了提高数据检索效率而创建的一种独立于表的存储结构,由Oracle系统自动进行维护. 索引的概述 索引是一种可选的与表或簇相关的数据库对象,能够为数据的查询提供快捷的存储路径,减少 ...
- 0801 RESTAPI设计,DRF 序列化
1.内容回顾 1.restframework serializer(序列化)的简单使用 QuereySet([obj,obj,obj]) --> JSON ...
- 数字代币ICO
随着比特币.莱特币.以太币的逐步兴起,越来越多的数字代币开始衍生,虚拟货币扑朔迷离,一不小心就被人割了韭菜..... 从荷兰IPO的故事说起 400多年前,西方有一群精英海盗开了一家公司.为了顺利拓展 ...
- 逐行读取txt文件并存入到数组中
get_file_contents_on_line.php $file = fopen("log.txt", "r"); $user=array(); $i=0 ...
- 简要总结ajax工作原理及优缺点
虽然在实际的项目中使用多种ajax请求,但就其工作原理,优缺点尚未深入总结, 参考:http://www.cnblogs.com/SanMaoSpace/archive/2013/06/15/3137 ...
- vm+ubuntu联网
在vm下刚装了ubuntu,就是上不了网,确认以下配置后方可以 1.我的电脑开机自动把VM的相关服务都关闭了,需要手动打开 在控制面板中搜索服务,手动启动vm服务 2.在适配器里启用vm网卡 3.使用 ...