概述
js中遍历获取对象属性和方法主要有Object.keys()、Object.getOwnPropertyNames()、for...in...三种方式
一、Object.keys()、Object.getOwnPropertyNames()、for...in...区别
1、for in会输出自身以及原型链上可枚举的属性。
2、Object.keys用来获取对象自身可枚举的属性键。
3、Object.getOwnPropertyNames用来获取对象自身的全部属性名
4、例如
// 不可枚举的对象属性
var nonenum = Object.create({}, {
getFoo: {
value: function () {
return this.foo;
},
enumerable: false
}
});
nonenum.foo = 1;
nonenum.asj = 2;
// 获取对象可枚举或不可枚举的属性
console.log(Object.getOwnPropertyNames(nonenum).sort()); // 输出 ["asj", "foo", "getFoo"]
// 获取对象可枚举的属性
console.log(Object.keys(nonenum).sort()); // 输出 ["asj", "foo"]
// 返回可枚举属性一直找到该对象的原型链
Object.prototype.newShine = "it's me";
for (var i in nonenum) {
console.log(i);// 输出 foo asj,newShine
}
// 返回直接定义在该对象上的可枚举属性
for (var i in nonenum) {
if (nonenum.hasOwnProperty(i)) {
console.log(i); // 输出 foo asj
}
}
二、分别获取JavaScript对象属性名和方法名
// 创建一个对象的构造方法
function myObj(name, attr) {
this.name = name;
this.attr = attr;
this.sayHi = function () {
return 'hi everyone!';
}
}
// 创建一个对象
var myTester = new myObj("shinejaie", 1)
// 获取对象方法
for (var i in myTester) {
if (myTester.hasOwnProperty(i) && typeof myTester[i] == "function") {
console.log("对象方法: ", i, "=", myTester[i])
}
}
// 输出 对象方法: sayHi = () { return 'hi everyone!'; }
// 获取对象属性
for (var i in myTester) {
if (myTester.hasOwnProperty(i) && typeof myTester[i] != "function") {
console.log("对象属性: ", i);
}
}
// 输出 对象属性: name 对象属性: attr
最后
以上就是朴素乐曲为你收集整理的js中遍历获取对象属性和方法主要的全部内容,希望文章能够帮你解决js中遍历获取对象属性和方法主要所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复