JS原型详解

本文详细解析了JavaScript中的原型概念,包括普通函数与构造函数的原型特性,通过实例展示了如何使用原型来扩展对象的功能,并讨论了instanceof操作符和typeof操作的区别及应用场景。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

参考的别人家的博客http://www.cnblogs.com/ljchow/archive/2010/06/08/1753526.html

###JS原型
####JS原型,就是原型对象,简称原型。不仅构造函数有,普通函数也有
* `普通函数:`
```javascript
function puTong(){

};

alert(puTong.prototype instanceof Object);//true
alert(puTong.prototype instanceof Function);//false
```

* `构造函数:`
```javascript
function A(x){
this.x = x;
}

A.prototype.a = "a";

function B(x,y){
this.y = y;
A.call(this.x);
}

B.prototype.b1 = function(){
alert("b1");
}

B.prototype = new A();

B.prototype.b2 = function(){
alert("b2");
}

B.prototype.constructor = B;
var obj = new B(1,3);
```


*instanceof只能判断对象和函数,返回值是布尔值。其余的例如数字、字符串等都不能判断 。例如:*

```javascript
var panDuan = new String("hello");
alert(panDuan instanceof String);//true
alert(typeof panDuan);//false
```

*typeof能判断一个元素的类型,也可以判断一个元素是否存在。例如:*

```javascript
alert(typeof 123); //number
alert(typeof "hello"); //string
alert(typeof function(){}); //function
alert(typeof true); //boolean
alert(typeof abc); //undefined
alert(typeof null); //object
```

 

转载于:https://www.cnblogs.com/songmengyao/p/7111238.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值