博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
js中构造函数和普通函数的区别
阅读量:4708 次
发布时间:2019-06-10

本文共 3105 字,大约阅读时间需要 10 分钟。

this简介:

this永远指向当前正在被执行的函数或方法的owner。例如:

1
2
3
4
5
function
test(){
  
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
function
Dog(){
  
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
function
Dog(){
  
this
.sound=
"汪汪汪"
;
}
Dog.prototype.bark=
function
(words){
  
alert(
this
.sound+
" "
+words);
}
var
dog=
new
Dog();
dog.bark(
"有小偷"
);
//alert:汪汪汪  有小偷
Dog.prototype.bark.call(cat,
"饿了"
);
//alert:喵喵喵  饿了

普通函数

这是一个简单的普通函数:

1
2
3
4
function
fn(){
  
alert(
"hello sheila"
);
}
fn();
//alert:hello sheila

普通函数与构造函数相比有四个明显特点:

1.不需要用new关键字调用

    fn();

2.可以用return语句返回值

1
2
3
4
function
fn(a,b){
   
return
a+b;
 
}
 
alert(fn(2,3));
//alert:5

3.函数内部不建议使用this关键字

我们说不建议使用,当然硬要用是可以的,只是要注意这时候发生了什么。如果在普通函数内部使用this关键字定义变量或函数,因为这时候this指向的是window全局对象,这样无意间就会为window添加了一些全局变量或函数。

1
2
3
4
5
6
function
greeting(){
    
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
function
Prince(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."
);
}
var
prince=
new
Prince(
"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
function
Person(name){
    
this
.name=name;
    
return
{name:
"cherry"
}
  
}
  
var
person=
new
Person(
"sheila"
);
  
person.name;
//cherry
  
p;
//Object {name: "cherry"}

转载于:https://www.cnblogs.com/wang98/p/7652377.html

你可能感兴趣的文章
.net开源CMS
查看>>
JdbcTemplate
查看>>
第一次使用maven记录
查看>>
SharePoint服务器端对象模型 之 使用CAML进展数据查询
查看>>
Building Tablet PC Applications ROB JARRETT
查看>>
Adobe® Reader®.插件开发
查看>>
【POJ 3461】Oulipo
查看>>
Alpha 冲刺 (5/10)
查看>>
使用Siege进行WEB压力测试
查看>>
斑马为什么有条纹?
查看>>
android多层树形结构列表学习笔记
查看>>
Android_去掉EditText控件周围橙色高亮区域
查看>>
《构建之法》第一、二、十六章阅读笔记
查看>>
arrow:让Python的日期与时间变的更好
查看>>
(转)Excel的 OleDb 连接串的格式(连接Excel 2003-2013)
查看>>
Java并发编程
查看>>
Git Stash用法
查看>>
sql server 2008学习8 sql server存储和索引结构
查看>>
Jquery radio选中
查看>>
memcached 细究(三)
查看>>