您的位置:首页 > Web前端 > JavaScript

JavaScript 获取对象属性和方法

2016-03-01 15:24 701 查看

ShineJaie 原创整理,转载请注明出处。

一、获取对象属性和方法

Object.keys() 返回对象的可枚举属性和方法名称数组
Object.getOwnPropertyNames()
返回的数组的所有属性(可枚举或不可枚举)直接找到给定对象。

// 创建一个对象的构造方法
function myObj(name, attr) {
this.name = name;
this.attr = attr;

this.sayHi = function () {
return 'hi everyone!!!';
}
}

// 创建一个对象
var myTester = new myObj("shinejaie", 1)
// 获取直接在对象上定义(可枚举)的属性和方法
var arr = Object.keys(myTester);
console.log('arr', arr); // 输出 arr ["name", "attr", "sayHi"]

// 返回的数组的所有属性(可枚举或不可枚举)直接找到给定对象。
console.log("attr", Object.getOwnPropertyNames(myTester)); // 输出 attr ["name", "attr", "sayHi"]

// 在 Object 原型上增加一个属性
Object.prototype.newShine = "it's me";

// 返回可枚举属性一直找到该对象的原型链
for (var i in myTester) {
console.log(i);
}
// 输出 name,attr,sayHi,newShine

// 返回直接定义在该对象上的可枚举属性
for (var i in myTester) {
if (myTester.hasOwnProperty(i)) {
console.log(i);
}
}
// 输出 name,attr,sayHi


二、Object.keys()、[b]
Object.getOwnPropertyNames()、for...in...对比
[/b]

// 不可枚举的对象属性
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"]

// 返回直接定义在该对象上的可枚举属性
for (var i in nonenum) {
if (nonenum.hasOwnProperty(i)) {
console.log(i); // 输出 foo asj
}
}


三、[b]分别获取JavaScript对象属性名和方法名[/b]

// 创建一个对象的构造方法
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
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: