分享web开发知识

注册/登录|最近发布|今日推荐

主页 IT知识网页技术软件开发前端开发代码编程运营维护技术分享教程案例
当前位置:首页 > 软件开发

【JS】for in循环对象,hasOwnProperty()的作用

发布时间:2023-09-06 01:24责任编辑:沈小雨关键词:暂无标签
var obj = { ???name:"echolun", ???age:"24", ???sex:"male"},objName=[], //用来装对象属性名objVal=[]; ?//用来装对象属性值for(var i in obj){ ???objName.push(i); ???objVal.push(obj[i]);}console.log(objName,objVal);

需要注意的是,for in循环对象会访问原型链上所有对象属性,看下面。

var obj = { ???name:"echolun", ???age:"24", ???sex:"male"},objName=[], //用来装对象属性名objVal=[]; ?//用来装对象属性值Object.prototype.game="lastgame";for(var i in obj){ ???objName.push(i); ???objVal.push(obj[i]);}console.log(objName,objVal);}

这里同样是循环对象obj,但是需要注意的是,原型链上我们额外添加的对象game也被循环出来。

那么我们只想循环对应的对象该怎么做呢,这里引入hasOwnProperty()方法,hasOwnProperty()函数用于指示一个对象自身(不包括原型链)是否具有指定名称的属性。如果有,返回true,否则返回false。

说简单点,它能帮你指向你当前循环的对象,而过滤掉原型链上其它对象,因为在工作中我们很难保证其他人是否会修改原型链,这样做会更为保险,那么修改代码。

var obj = { ???name:"echolun", ???age:"24", ???sex:"male"},objName=[], //用来装对象属性名objVal=[]; ?//用来装对象属性值Object.prototype.game="lastgame";for(var i in obj){ ???if(obj.hasOwnProperty(i)) { ???????objName.push(i); ???????objVal.push(obj[i]); ???}}console.log(objName,objVal);}

看吧,这下就过滤掉game了。

【JS】for in循环对象,hasOwnProperty()的作用

原文地址:http://www.cnblogs.com/echolun/p/7816084.html

知识推荐

我的编程学习网——分享web前端后端开发技术知识。 垃圾信息处理邮箱 tousu563@163.com 网站地图
icp备案号 闽ICP备2023006418号-8 不良信息举报平台 互联网安全管理备案 Copyright 2023 www.wodecom.cn All Rights Reserved