我是靠谱客的博主 朴素乐曲,最近开发中收集的这篇文章主要介绍js中遍历获取对象属性和方法主要,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

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中遍历获取对象属性和方法主要所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(41)

评论列表共有 0 条评论

立即
投稿
返回
顶部