JavaScript中的普通函数与构造函数比较
问题
什么是构造函数?
构造函数与普通函数区别是什么?
用new关键字的时候到底做了什么?
构造函数有返回值怎么办?
构造函数能当普通函数调用吗?
this
this永远指向当前正在被执行的函数或方法的owner。例如:
| 1 2 3 4 5 | functiontest(){  console.log(this);}test();//Window {top: Window, window: Window, location: Location, external: Object, chrome: Object…} | 
上面这段代码中,我们在页面中定义了一个test()函数,然后在页面中调用。函数定义在全局时,其owner就是当前页面,也就是window对象。
this指向的几种情况
1.全局中调用
this.name //this指向window对象
    
2.函数调用
test();//test()函数中的this也指向window对象
    
3.对象的方法调用
obj1.fn();//obj1对象的fn()方法中的this指向obj1
    
4.调用构造函数
    var dog=new Dog();//构造函数内的this指向新创建的实例对象,也就是这里的dogcall和apply
call和apply的作用一样,只是接受参数的方式不一样,call接受的是多个单个参数,apply接受的是参数数组。
call和apply的作用简单地可以说成,当一个对象实例缺少一个函数/方法时,可以调用其他对象的现成函数/方法,其方式是通过替换其中的this为这个对象实例,改变函数运行时的上下文。
例如:
| 1 2 3 4 5 6 | functionDog(){  this.sound="汪汪汪";}Dog.prototype.bark=function(){  alert(this.sound);} | 
现在我有另外一个cat对象:
var cat={sound:'喵喵喵'}
我也想让这个cat对象可以调用bark方法,这时候就不用重新为它定义bark方法了,可以用call/apply调用Dog类的bark方法:
Dog.prototype.bark.call(cat);
或者:
dog.bark.call(cat);
加点东西,变成一个带参数的例子:
| 1 2 3 4 5 6 7 8 9 | functionDog(){  this.sound="汪汪汪";}Dog.prototype.bark=function(words){  alert(this.sound+" "+words);}vardog=newDog();dog.bark("有小偷");//alert:汪汪汪  有小偷Dog.prototype.bark.call(cat,"饿了");//alert:喵喵喵  饿了 | 
普通函数
这是一个简单的普通函数:
| 1 2 3 4 | functionfn(){  alert("hello sheila");}fn();//alert:hello sheila | 
普通函数与构造函数相比有四个明显特点:
1.不需要用new关键字调用
fn();2.可以用return语句返回值
| 1 2 3 4 | functionfn(a,b){   returna+b; } alert(fn(2,3));//alert:5 | 
3.函数内部不建议使用this关键字
我们说不建议使用,当然硬要用是可以的,只是要注意这时候发生了什么。如果在普通函数内部使用this关键字定义变量或函数,因为这时候this指向的是window全局对象,这样无意间就会为window添加了一些全局变量或函数。
| 1 2 3 4 5 6 | functiongreeting(){    this.name="sheila";    alert("hello "+this.name);  }  greeting();//alert:hello sheila  alert(window.name);//alert:sheila | 
4.函数命名以驼峰方式,首字母小写
构造函数
在JavaScript中,用new关键字来调用定义的构造函数。默认返回的是一个新对象,这个新对象具有构造函数定义的变量和函数/方法。
举个例子:
| 1 2 3 4 5 6 7 8 9 10 11 12 13 | functionPrince(name,age){  this.gender="male";  this.kind=true;  this.rich=true;  this.name=name;  this.age=age;}Prince.prototype.toFrog=function(){  console.log("Prince "+this.name+" turned into a frog.");}varprince=newPrince("charming",25);prince.toFrog();//Prince charming turned into a frog.prince.kind;//true | 
与普通函数相比,构造函数有以下明显特点:
1.用new关键字调用
var prince=new Prince("charming",25);
2.函数内部可以使用this关键字
在构造函数内部,this指向的是构造出的新对象。用this定义的变量或函数/方法,就是实例变量或实例函数/方法。需要用实例才能访问到,不能用类型名访问。
prince.age;//25
    Prince.age;//undefined
3.默认不用return返回值
构造函数是不需要用return显式返回值的,默认会返回this,也就是新的实例对象。当然,也可以用return语句,返回值会根据return值的类型而有所不同,细节将在下文介绍。
4.函数命名建议首字母大写,与普通函数区分开。
不是命名规范中的,但是建议这么写。
使用new关键字实例化的时候发生了什么?
以上文中的Prince()函数举个例子:
1.第一步,创建一个空对象。
var prince={}
2.第二步,将构造函数Prince()中的this指向新创建的对象prince。
3.第三步,将prince的_proto_属性指向Prince函数的prototype,创建对象和原型间关系
4.第四步,执行构造函数Prince()内的代码。
构造函数有return值怎么办?
构造函数里没有显式调用return时,默认是返回this对象,也就是新创建的实例对象。
当构造函数里调用return时,分两种情况:
1.return的是五种简单数据类型:String,Number,Boolean,Null,Undefined。
这种情况下,忽视return值,依然返回this对象。
2.return的是Object
这种情况下,不再返回this对象,而是返回return语句的返回值。
| 1 2 3 4 5 6 7 | functionPerson(name){    this.name=name;    return{name:"cherry"}  }  varperson=newPerson("sheila");  person.name;//cherry  p;//Object {name: "cherry"} | 
JavaScript中的普通函数与构造函数比较的更多相关文章
- JavaScript中的普通函数与构造函数
		问题 什么是构造函数? 构造函数与普通函数区别是什么? 用new关键字的时候到底做了什么? 构造函数有返回值怎么办? 构造函数能当普通函数调用吗? 以下是我的一些理解,理解错误的地方恳请大家帮忙指正, ... 
- JavaScript中的普通函数和构造函数
		在写JavaScript代码过程中,用到需要写构造函数的地方不多,但还是需要详细了解一下 本文尽量描述清楚什么是JavaScript中的构造函数,以及普通函数和构造函数的区别 
- [转]JavaScript中的匿名函数及函数的闭包
		JavaScript中的匿名函数及函数的闭包 原文地址:http://www.cnblogs.com/wl0000-03/p/6050108.html 1.匿名函数 函数是JavaScript中最灵 ... 
- JavaScript中的匿名函数及函数的闭包(转)
		JavaScript中的匿名函数及函数的闭包 https://www.cnblogs.com/wl0000-03/p/6050108.html 1.匿名函数 函数是JavaScript中最灵活的一种 ... 
- JavaScript中的工厂方法、构造函数与class
		JavaScript中的工厂方法.构造函数与class 本文转载自:众成翻译 译者:谢于中 链接:http://www.zcfy.cc/article/1129 原文:https://medium.c ... 
- 理解与使用Javascript中的回调函数 -2
		在javascript中回调函数非常重要,它们几乎无处不在.像其他更加传统的编程语言都有回调函数概念,但是非常奇怪的是,完完整整谈论回调函数的在线教程比较少,倒是有一堆关于call()和apply() ... 
- javascript中什么是函数
		函数的定义 在javascript中函数是一段可以被执行或调用任意次数的JavasScript代码,在数据类型中属于"function".函数也拥有属性和方法,因此函数也是对象. ... 
- 借助JavaScript中的时间函数改变Html中Table边框的颜色
		借助JavaScript中的时间函数改变Html中Table边框的颜色 <html> <head> <meta http-equiv="Content-Type ... 
- 前端学习 第二弹: JavaScript中的一些函数与对象(1)
		前端学习 第二弹: JavaScript中的一些函数与对象(1) 1.apply与call函数 每个函数都包含两个非继承而来的方法:apply()和call(). 他们的用途相同,都是在特定的作用域中 ... 
随机推荐
- Asp.Net回车键触发Button的OnClick事件解决方案
			在aspx页面有textbox文本框,还有三个button按钮.启用textbox的TextChanged事件和button的click事件. 问题: 现在在textbox文本框输入完数据按“回车”后 ... 
- Office英语学习好帮手
			Office提供了强大实用的英语学习助手,它可以自动翻译中英文,还可以显示详尽的解释帮助信息,当然标准的发音也是必不可少的.如何启动屏幕取词翻译功能呢?如何让office自动取词并翻译呢?如何收听单词 ... 
- 使用 CSS3 制作一组超时尚的动画按钮效果
			通过 CSS3 的新特性,我们创作出好的交互和效果的可能性大大增加.这篇文章中,我想与大家分享一些 CSS3 动画按钮效果.我们的想法是创建一个具有不同风格的一些动画链接元素,鼠标悬停时有动画效果和活 ... 
- Web 开发人员和设计师必读文章推荐【系列二十九】
			<Web 前端开发精华文章推荐>2014年第8期(总第29期)和大家见面了.梦想天空博客关注 前端开发 技术,分享各类能够提升网站用户体验的优秀 jQuery 插件,展示前沿的 HTML5 ... 
- 在与 SQL Server 建立连接时出现与网络相关的或特定于实例的错误
			在visual studio 中添加数据库应用时,报错,提示如下: 在与 SQL Server 建立连接时出现与网络相关的或特定于实例的错误.未找到或无法访问服务器.请验证实例名称是否正确并且 SQL ... 
- iOS_UIImage_jpg<-->png转换
			// png 图片转化是无损的. 可以有透明效果. // jpg 图片转化是有损的. 质量因子. - (void)jpgToPng { UIImage * image = [UIImage image ... 
- SQL SERVER 内存分配及常见内存问题 简介
			一.问题: 1.SQL Server 所占用内存数量从启动以后就不断地增加: 首先,作为成熟的产品,内存溢出的机会微乎其微.对此要了解SQL SERVER与windows是如何协调.共享内存.并且SQ ... 
- 阅读《LEARNING HARD C#学习笔记》知识点总结与摘要二
			今天继续分享我的阅读<LEARNING HARD C#学习笔记>知识点总结与摘要二,仍然是基础知识,但可温故而知新. 七.面向对象 三大基本特性: 封装:把客观事物封装成类,并隐藏类的内部 ... 
- 一个有意思的js小问题
			问题:如何实现以下函数? add(2, 5); // 7 add(2)(5); // 7 第一个就不用说了,很简单,关键是看第二个,add(2)(5),可见add(2)应该返回的是一个函数,这个函数再 ... 
- C# Graphics绘图 picBox
			需求: Bitmap bm = new Bitmap(picboxPreview.Width, picboxPreview.Height); using (Graphics g = Graphics. ... 
