博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
JavaScript 获取对象属性和方法
阅读量:6903 次
发布时间:2019-06-27

本文共 2610 字,大约阅读时间需要 8 分钟。

 

 一、获取对象属性和方法

Object.keys() 返回对象的可枚举属性和方法名称数组
Object.getOwnPropertyNames() 返回的数组的所有属性(可枚举或不可枚举)直接找到给定对象。
1     // 创建一个对象的构造方法 2     function myObj(name, attr) { 3         this.name = name; 4         this.attr = attr; 5  6         this.sayHi = function () { 7             return 'hi everyone!!!'; 8         } 9     }10 11     // 创建一个对象12     var myTester = new myObj("shinejaie", 1)13     // 获取直接在对象上定义(可枚举)的属性和方法14     var arr = Object.keys(myTester);15     console.log('arr', arr); // 输出 arr ["name", "attr", "sayHi"]16 17     // 返回的数组的所有属性(可枚举或不可枚举)直接找到给定对象。18     console.log("attr", Object.getOwnPropertyNames(myTester)); // 输出 attr ["name", "attr", "sayHi"]19 20     // 在 Object 原型上增加一个属性21     Object.prototype.newShine = "it's me";22 23     // 返回可枚举属性一直找到该对象的原型链24     for (var i in myTester) {25         console.log(i);26     }27     // 输出 name,attr,sayHi,newShine28 29     // 返回直接定义在该对象上的可枚举属性30     for (var i in myTester) {31         if (myTester.hasOwnProperty(i)) {32             console.log(i);33         }34     }35     // 输出 name,attr,sayHi

二、Object.keys()、Object.getOwnPropertyNames()、for...in...对比

1     // 不可枚举的对象属性 2     var nonenum = Object.create({}, { 3         getFoo: { 4             value: function () { 5                 return this.foo; 6             }, 7             enumerable: false 8         } 9     });10     nonenum.foo = 1;11     nonenum.asj = 2;12 13     // 获取对象可枚举或不可枚举的属性14     console.log(Object.getOwnPropertyNames(nonenum).sort()); // 输出 ["asj", "foo", "getFoo"]15 16     // 获取对象可枚举的属性17     console.log(Object.keys(nonenum).sort()); // 输出 ["asj", "foo"]18 19     // 返回直接定义在该对象上的可枚举属性20     for (var i in nonenum) {21         if (nonenum.hasOwnProperty(i)) {22             console.log(i); // 输出 foo asj23         }24     }

 三、分别获取JavaScript对象属性名和方法名

1     // 创建一个对象的构造方法 2     function myObj(name, attr) { 3         this.name = name; 4         this.attr = attr; 5  6         this.sayHi = function () { 7             return 'hi everyone!!!'; 8         } 9     }10 11     // 创建一个对象12     var myTester = new myObj("shinejaie", 1)13 14     // 获取对象方法15     for (var i in myTester) {16         if (myTester.hasOwnProperty(i) && typeof myTester[i] == "function") {17             console.log("对象方法: ", i, "=", myTester[i])18         }19     }20     // 输出 对象方法: sayHi = () { return 'hi everyone!!!'; }21 22     // 获取对象属性23     for (var i in myTester) {24         if (myTester.hasOwnProperty(i) && typeof myTester[i] != "function") {25             console.log("对象属性: ", i);26         }27     }28     // 输出 对象属性: name 对象属性: attr

 

 

 

 

转载于:https://www.cnblogs.com/shinejaie/p/5231195.html

你可能感兴趣的文章
git将一个分支完全覆盖另外一个分支如:stable分支代码完全覆盖brush分支
查看>>
yii2获取用户get,post参数
查看>>
编辑于20140505
查看>>
Java常用的八种排序算法与代码实现
查看>>
数据库中Schema和Database有什么区别
查看>>
nginx笔记.
查看>>
面试题35-第一个值出现依次的字符
查看>>
jquery的 $.Event()
查看>>
C# 中的值类型和引用类型一览
查看>>
PHP编写代码目的、要求、规范及细节
查看>>
浅谈JVM内存模型
查看>>
IRC僵尸网络原理
查看>>
RIPng(第三组)
查看>>
后端传给前端Long类型数据,导致精度丢失
查看>>
SpringMvc 与 Struts2的区别
查看>>
实验四 恶意代码技术
查看>>
快速打出System.out.println("");
查看>>
kermit的安装、配置、使用
查看>>
shell编程学习
查看>>
忙中记录
查看>>