JavaScript isPrototypeOf和hasOwnProperty使用区别
作者:bea
1、isPrototypeOf isPrototypeOf是用来判断指定对象object1是否存在于另一个对象object2的原型链中,是则返回true,否则返回false。 格式如下: object1.isPrototypeOf(object2); object1是一个对象的实例; object2是另一个将要检查其原型链的对象。 原型链可以用来在同一个对象类型的不同实例之间共享功能。 如果 object2 的原型链中包含object1,那么 isPrototypeOf 方法
1、isPrototypeOf
isPrototypeOf是用来判断指定对象object1是否存在于另一个对象object2的原型链中,是则返回true,否则返回false。
格式如下:
object1.isPrototypeOf(object2);
object1是一个对象的实例;
object2是另一个将要检查其原型链的对象。
原型链可以用来在同一个对象类型的不同实例之间共享功能。
如果 object2 的原型链中包含object1,那么 isPrototypeOf 方法返回 true。
如果 object2 不是一个对象或者 object1 没有出现在 object2 中的原型链中,isPrototypeOf 方法将返回 false。
使用举例如下:
代码如下:
var re = /^s*/;
// 这里定义一个正则表达式对象
// 这里检查RegExp是不是re的原形链对象,返回true
var bIsptt = RegExp.prototype.isPrototypeOf(re);
2、hasOwnProperty hasOwnProperty判断一个对象是否有名称的属性或对象,此方法无法检查该对象的原型链中是否具有该属性,该属性必须是对象本身的一个成员。
如果该属性或者方法是该 对象自身定义的而不是器原型链中定义的 则返回true;否则返回false;
格式如下:
object.hasOwnProperty(proName);
判断proName的名称是不是object对象的一个属性或对象。使用举例如下:
代码如下:
// 得到false, 因为不能检测原型链中的属性
var bStr = "Test String".hasOwnProperty("split");
// String对象的原型上本来就有这个属性,自然返回true
var bStr1 = String.prototype.hasOwnProperty("split");
// 返回true,因为不是检测原型中的属性
var bObj = ({fnTest:function(){}}).hasOwnProperty("fnTest");
有用 | 无用
isPrototypeOf是用来判断指定对象object1是否存在于另一个对象object2的原型链中,是则返回true,否则返回false。
格式如下:
object1.isPrototypeOf(object2);
object1是一个对象的实例;
object2是另一个将要检查其原型链的对象。
原型链可以用来在同一个对象类型的不同实例之间共享功能。
如果 object2 的原型链中包含object1,那么 isPrototypeOf 方法返回 true。
如果 object2 不是一个对象或者 object1 没有出现在 object2 中的原型链中,isPrototypeOf 方法将返回 false。
使用举例如下:
代码如下:
var re = /^s*/;
// 这里定义一个正则表达式对象
// 这里检查RegExp是不是re的原形链对象,返回true
var bIsptt = RegExp.prototype.isPrototypeOf(re);
2、hasOwnProperty hasOwnProperty判断一个对象是否有名称的属性或对象,此方法无法检查该对象的原型链中是否具有该属性,该属性必须是对象本身的一个成员。
如果该属性或者方法是该 对象自身定义的而不是器原型链中定义的 则返回true;否则返回false;
格式如下:
object.hasOwnProperty(proName);
判断proName的名称是不是object对象的一个属性或对象。使用举例如下:
代码如下:
// 得到false, 因为不能检测原型链中的属性
var bStr = "Test String".hasOwnProperty("split");
// String对象的原型上本来就有这个属性,自然返回true
var bStr1 = String.prototype.hasOwnProperty("split");
// 返回true,因为不是检测原型中的属性
var bObj = ({fnTest:function(){}}).hasOwnProperty("fnTest");
有用 | 无用
猜你喜欢
您可能感兴趣的文章:
- Jquery Validation插件防止重复提交表单的解决方法
- javascript下判断一个元素是否存在的代码
- ExtJs扩展之GroupPropertyGrid代码
- js 获取服务器控件值的代码
- jquery checkbox全选、取消全选实现代码
- javascript 隐藏/显示指定的区域附HTML元素【legend】用法
- ExtJS 工具栏 分页事件参数
- Microsoft Ajax Minifier 压缩javascript的方法
- JavaScript屏蔽指定区域内右键菜单
- javascript 浏览器检测代码精简版
- 前端开发部分总结[兼容性、DOM操作、跨域等](持续更新)
- jquery与google map api结合使用 控件,监听器
- jquery 打开窗口返回值实现代码
- jQuery入门知识简介
- jQuery 获取URL参数的插件
- 老鱼 浅谈javascript面向对象编程
- javascript实现的像java、c#之类的sleep暂停的函数代码
- ExtJs之带图片的下拉列表框插件
- JavaScript replace(rgExp,fn)正则替换的用法